多くの場合、私たちは新しいプロジェクトに出会ってから開発が完了するまで、自分が書いたコードをじっくりと読み返します。その多くは以前に使いこなしたコードです。したがって、新しいプロジェクトを完了するたびに、プロジェクトの概要とコードの概要を適切に実行すると、将来のプロジェクトでそれを使用できるようになり、コードの最適化やより良いアイデア、より迅速な実装方法など、予期せぬ利益が得られる可能性が非常に高くなります。 。
優れたプログラム開発者を決定するのは、コードの量ではなく、コードの単純さと、複雑なロジックにもかかわらず実装の容易さである場合があります。これらは、プログラマーが優れたプログラマーであるかどうかを示す要素です。私たちは、昼も夜も夜遅くまで残業して、大量のコードを急いで書くプログラマーにはなりたくないのです。
このブログでは、いくつかの PHP プログラミング スキルを共有します。スキルの中には、他の人のコードを見て学んだものと、私自身が要約したものがあります。
特定のフィールドをインデックスとして使用して、データベースからフェッチしたデータ配列を返します
例を挙げると簡単です:
他の Web サイトからの指定されたサイトのトラフィックをカウントし、そのための小さなバックエンドを作成するとします。各ウェブサイトの毎日の受信トラフィック状況を確認します。まず 2 つのデータ テーブルを構築します:
テーブル 1、サイト構成テーブル (これらの Web サイトのトラフィックのみをカウントします)
CREATE TABLE `site_config` ( `id` smallint(5) unsigned NOT NULL auto_increment COMMENT '主键,自增', `sid` smallint(5) unsigned NOT NULL COMMENT '网站ID', `site_url` varchar(128) NOT NULL COMMENT '网站URL地址', `site_name` varchar(80) NOT NULL COMMENT '网站名称', `add_time` timestamp NOT NULL default CURRENT_TIMESTAMP COMMENT '添加时间', PRIMARY KEY (`id`), UNIQUE KEY `adid` (`sid`)) ENGINE=MyISAM DEFAULT CHARSET=utf8 COMMENT='站点配置表';
テーブル 2、サイト トラフィック統計テーブル (ユーザーごとに 1 つのレコード)
CREATE TABLE `site_stat` ( `id` int(11) unsigned NOT NULL auto_increment COMMENT '主键,自增', `sid` smallint(5) unsigned NOT NULL COMMENT '网站ID', `ip_address` varchar(32) NOT NULL COMMENT '用户IP', `add_time` timestamp NOT NULL default CURRENT_TIMESTAMP COMMENT '添加时间', PRIMARY KEY (`id`)) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='站点流量统计表' ;
site_config テーブルの読み取り操作は書き込み操作よりも大きく、タイプは MyISAM に設定され、site_stat テーブルの書き込み操作は読み取り操作よりも大きいため、テーブル タイプを InnoDB に設定します。 (これらはデータ設計時に考慮する必要があることであり、速度が大幅に向上します)。
トピックに戻り、テーブル site_config に複数のデータがある場合:
データ形式は次のとおりです: id、sid、site_url、add_time
1,200,baidu.com,2013-06-30 14: 20:00
2,201,google.com,2013-06-30 14:20:00
3,202,cnblogs.com,2013-06-30 14:20:00
4,203,codejia.net,2013-06 -30 14: 20:00
次のように、サイト トラフィック統計テーブル site_stat にいくつかのデータが生成されました:
データ形式は次のとおりです: id,sid,ip_address,add_time
1,200,167.87.32.4,2013-06 -30 14:40:00
2,200,192.168.11.56、2013-06-30 14:40:10
3,202,167.87.32.4、2013-06-30 14:40:10
4,202,192.16 8.11.56 、2013-06-30 14 :40:205.203.167.87.32.4,2013-06-30 14:40:20 4:40:31
バックグラウンドで実行する必要があるレポート形式は次のとおりです: 日付、Web サイト ID、Web サイト URL 、トラフィック数 (トラフィックのないサイトも表示される必要があり、トラフィックは 0 として表示されます)
日付に基づいて、テーブル site_stat sid group by と左結合テーブル site_config を考えることができますが、これは明らかにそうではありませんその方法をシェアします。
これを行うには 2 つの SQL を使用します。1 つはすべてのサイトを取得することで、もう 1 つは指定された日付のサイトのトラフィック統計を取得することです。
すべてのサイトを取得する SQL1:
SELECT sid,site_url,site_name FROM site_config
サイト統計を取得する SQL2 (今日の場合):
SELECT sid,COUNT(1) AS come_total FROM site_stat WHERE add_time>='2013-06-30 00:00:00' AND add_time<='2013-06-30 23:59:59'GROUP BY sid
前に述べたことの多くは、将来への道を切り開く、フィールドを共有するというものです。インデックス付けの場合、2 次元配列を返すメソッド:
protected function getList($sql,$filed = null){ $res = mysql_query($sql,$this->link_sc); $data = array(); if($filed === null){ while($row = mysql_fetch_assoc($res)){ $data[] = $row; } }else{ while($row = mysql_fetch_assoc($res)){ $data[$row[$filed]] = $row; } } return $data; }
SQL とインデックス付けが必要なフィールドを渡すと、フィールドが渡されることが前提となります。 select によって返されるフィールドに存在する必要があります。
すべてのサイトを取得するときに過去のフィールドを渡す必要はありませんが、サイトのトラフィック統計を取得するときに、次のようにサイト sid を渡します:
$sites = getList($sql1); //所有站点$data = getList($sql2,'sid'); //站点流量数据,以sid为索引返回二维数组
最後に、レポートを表示するときに、foreach ループを使用します。 $ sites は、トラフィックを取得するときに、配列 $data に移動し、インデックス sid を持つデータを取得します。
とても便利でマスターしやすいので、よく使います。
最後に、上の表の統計結果レポートを見てください:
形式は次のとおりです: 日付、Web サイト ID、Web サイト URL、トラフィック数
2013-06-30,200,baidu.com,3
2013-06-30,201 ,google.com,0
2013-06-30,202,cnblogs.com,3
2013-06-30,203,codejia.net,1
要約: これほど多くのことを書くことは、そのような小さなスキルを示しているだけのようです。ただし、このテクニックを過小評価しないでください。時間を大幅に節約できます。そのため、皆さんもコードを書くときにもっとまとめて、ブログパークに来てみんなとコミュニケーションを取りながら学んでいけば、あなたのプログラミングレベルは確実に早く上がります!

セッション関連のXSS攻撃からアプリケーションを保護するには、次の測定が必要です。1。セッションCookieを保護するためにHTTPonlyとセキュアフラグを設定します。 2。すべてのユーザー入力のエクスポートコード。 3.コンテンツセキュリティポリシー(CSP)を実装して、スクリプトソースを制限します。これらのポリシーを通じて、セッション関連のXSS攻撃を効果的に保護し、ユーザーデータを確保できます。

PHPセッションのパフォーマンスを最適化する方法は次のとおりです。1。遅延セッション開始、2。データベースを使用してセッションを保存します。これらの戦略は、高い並行性環境でのアプリケーションの効率を大幅に改善できます。

thesession.gc_maxlifettinginttinginphpdethinesthelifsessessiondata、setinseconds.1)it'sconfiguredinphp.iniorviaini_set()。 2)AbalanceSneededToAvoidPerformanceIssues andunexpectedLogouts.3)php'sgarbagecollectionisisprobabilistic、影響を受けたBygc_probabi

PHPでは、session_name()関数を使用してセッション名を構成できます。特定の手順は次のとおりです。1。session_name()関数を使用して、session_name( "my_session")などのセッション名を設定します。 2。セッション名を設定した後、session_start()を呼び出してセッションを開始します。セッション名の構成は、複数のアプリケーション間のセッションデータの競合を回避し、セキュリティを強化することができますが、セッション名の一意性、セキュリティ、長さ、設定タイミングに注意してください。

セッションIDは、機密操作の前、30分ごとにログイン時に定期的に再生する必要があります。 1.セッション固定攻撃を防ぐためにログインするときにセッションIDを再生します。 2。安全性を向上させるために、敏感な操作の前に再生します。 3.定期的な再生は長期的な利用リスクを減らしますが、ユーザーエクスペリエンスの重量を量る必要があります。

PHPのセッションCookieパラメーターの設定は、session_set_cookie_params()関数を通じて達成できます。 1)この関数を使用して、有効期限、パス、ドメイン名、セキュリティフラグなどのパラメーターを設定します。 2)session_start()を呼び出して、パラメーターを有効にします。 3)ユーザーログインステータスなど、ニーズに応じてパラメーターを動的に調整します。 4)セキュリティを改善するために、セキュアとhttponlyフラグを設定することに注意してください。

PHPでセッションを使用する主な目的は、異なるページ間でユーザーのステータスを維持することです。 1)セッションはsession_start()関数を介して開始され、一意のセッションIDを作成し、ユーザーCookieに保存します。 2)セッションデータはサーバーに保存され、ログインステータスやショッピングカートのコンテンツなど、さまざまなリクエスト間でデータを渡すことができます。

サブドメイン間でセッションを共有する方法は?一般的なドメイン名にセッションCookieを設定することにより実装されます。 1.セッションCookieのドメインをサーバー側の.example.comに設定します。 2。メモリ、データベース、分散キャッシュなど、適切なセッションストレージ方法を選択します。 3. Cookieを介してセッションIDを渡すと、サーバーはIDに基づいてセッションデータを取得および更新します。


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

SAP NetWeaver Server Adapter for Eclipse
Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。

Dreamweaver Mac版
ビジュアル Web 開発ツール

SublimeText3 英語版
推奨: Win バージョン、コードプロンプトをサポート!

MantisBT
Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

WebStorm Mac版
便利なJavaScript開発ツール
