{"id":2465,"date":"2015-10-06T23:07:35","date_gmt":"2015-10-06T14:07:35","guid":{"rendered":"http:\/\/taitan916.info\/blog\/?p=2465"},"modified":"2024-01-18T16:12:12","modified_gmt":"2024-01-18T07:12:12","slug":"post-2465","status":"publish","type":"post","link":"https:\/\/taitan916.info\/blog\/archives\/2465","title":{"rendered":"PHP\u306e\u30ed\u30b0\u30a4\u30f3\u8a8d\u8a3c\u3092PEAR::Auth\u30d1\u30c3\u30b1\u30fc\u30b8\u3067\u5b9f\u88c5\u3059\u308b\u65b9\u6cd5"},"content":{"rendered":"<p>PHP\u306e\u30b7\u30b9\u30c6\u30e0\u3067\u3042\u308b\u7a0b\u5ea6\u3061\u3083\u3093\u3068\u3057\u305f\u30ed\u30b0\u30a4\u30f3\u30b7\u30b9\u30c6\u30e0\u304c\u5fc5\u8981\u306b\u306a\u3063\u305f\u3002\u4eca\u307e\u3067\u30ed\u30b0\u30a4\u30f3\u5468\u308a\u306fCOOKIE\u3067\u3084\u3063\u3066\u304d\u305f\u3051\u3069\u3001\u591a\u5206\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u3068\u304b\u5371\u306a\u305d\u3046\u3002<\/p>\n<p>\u304b\u3068\u3044\u3063\u3066\u30bb\u30c3\u30b7\u30e7\u30f3\u306f\u3042\u307e\u308a\u4f7f\u3063\u3066\u3044\u306a\u3044\u306e\u3067\u60a9\u3093\u3067\u3044\u305f\u3068\u3053\u308d\u3001<a href=\"https:\/\/pear.php.net\/package\/Auth\" target=\"_blank\" rel=\"noopener\">PEAR\u306eAuth\u30d1\u30c3\u30b1\u30fc\u30b8<\/a>\u3068\u3044\u3046\u306e\u304c\u826f\u3044\u3068\u805e\u3044\u305f\u3002\u5b9f\u88c5\u6642\u306e\u30e1\u30e2\u3002<\/p>\n<p>&nbsp;<\/p>\n<h2><strong>\u4e8b\u524d\u6e96\u5099<\/strong><\/h2>\n<p>pear\u306eAuth\u3068DB\u3068\u3044\u3046\u306e\u304c\u5fc5\u8981\u306a\u306e\u3067SSH\u304b\u3089\u4ee5\u4e0b\u30b3\u30de\u30f3\u30c9\u3067\u5c0e\u5165\u3059\u308b\u3002<\/p>\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\">pear install Auth\r\npear install DB<\/pre>\n<p>&nbsp;<\/p>\n<h2><strong>\u30bd\u30fc\u30b9<\/strong><\/h2>\n<h3>\u30ed\u30b0\u30a4\u30f3\u30da\u30fc\u30b8<\/h3>\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\">&lt;html&gt;\r\n&lt;head&gt;\r\n&lt;title&gt;login&lt;\/title&gt;\r\n&lt;\/head&gt;\r\n&lt;body&gt;\r\n&lt;?php\r\ninclude_once \"Auth\/Auth.php\";\r\ninclude_once 'DB.php';\r\nfunction loginFunction($username, $status){\r\n    echo '\r\n        &lt;form method=\"post\" action=\"'.$_SERVER['PHP_SELF'].'\"&gt;\r\n            &lt;input type=\"text\" name=\"username\" placeholder=\"username\"&gt;&lt;br&gt;\r\n            &lt;input type=\"text\" name=\"password\" placeholder=\"password\"&gt;&lt;br&gt;\r\n            &lt;input type=\"submit\"&gt;\r\n        &lt;\/form&gt;\r\n    ';\r\n}\r\n$params = array(\r\n    \"dsn\" =&gt; \"mysqli:\/\/{$database_user}:{$database_pass}@{$database_host}\/{$database_name}\", \/\/MySQL\u306e\u30a2\u30ab\u30a6\u30f3\u30c8\u60c5\u5831\u3092\u5165\u308c\u308b\r\n    \"table\" =&gt; $database_table, \/\/\u8a8d\u8a3c\u306b\u4f7f\u3046\u30c6\u30fc\u30d6\u30eb\u3092\u6307\u5b9a\r\n    \"usernamecol\" =&gt; \"username\", \/\/id\u3084mailadress\u7b49\u3092\u4f7f\u3044\u305f\u3044\u5834\u5408\u306f\u3053\u3053\u306e\u5024\u3092\u5909\u3048\u308b\r\n    \"passwordcol\" =&gt; \"password\",\r\n    'db_fields' =&gt; \"*\" \/\/\u3053\u308c\u3092\u6307\u5b9a\u3057\u3066\u304a\u304f\u3068\u8a72\u5f53\u30e6\u30fc\u30b6\u30fc\u306e\u4ed6\u306e\u7d61\u3080\u60c5\u5831\u3082\u53d6\u5f97\u3067\u304d\u308b\r\n);\r\n$login = new Auth(\"DB\", $params, \"loginFunction\");\r\n$login-&gt;start();\r\n\r\nif ( $login-&gt;getAuth() ){\r\n    \/\/\u30ed\u30b0\u30a4\u30f3\u6210\u529f\u6642\u306e\u51e6\u7406\r\n}\r\n?&gt;\r\n&lt;\/body&gt;\r\n&lt;\/html&gt;<\/pre>\n<p>&nbsp;<\/p>\n<h3>\u305d\u306e\u4ed6\u306e\u30da\u30fc\u30b8(\u30bb\u30c3\u30b7\u30e7\u30f3\u3092\u5f15\u304d\u56de\u3059\u30da\u30fc\u30b8)<\/h3>\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\">&lt;?php\r\ninclude_once \"Auth\/Auth.php\";\r\ninclude_once 'DB.php';\r\n\r\nfunction checkUserLogin(){\r\n\r\n    if( !$_COOKIE['PHPSESSID'] || !$_COOKIE['authchallenge'] ){ \/\/COOKIE\u306b\u6b8b\u3063\u3066\u306a\u3044\u5834\u5408\u306f\u30ed\u30b0\u30a2\u30a6\u30c8\u3057\u3066\u3044\u308b\u3082\u306e\u3068\u307f\u306a\u3059\r\n        return false;\r\n    }\r\n\r\n    $auth = new Auth('DB');\r\n    $auth-&gt;start();\r\n    if ($auth-&gt;getAuth()){\r\n        $user = array( \/\/getAuthData($key)\u306e$key\u306f\u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u306e\u30ab\u30e9\u30e0\u540d\r\n            'id' =&gt; $auth-&gt;getAuthData(\"id\"), \r\n            'mail' =&gt; $auth-&gt;getAuthData(\"mail\"), \r\n            'date' =&gt; $auth-&gt;getAuthData(\"date\")\r\n        );\r\n    }else{ \/\/COOKIE\u306b\u6b8b\u3063\u3066\u3044\u3066\u30ed\u30b0\u30a4\u30f3\u3067\u304d\u306a\u3044\u5834\u5408\u306f\u30bb\u30c3\u30b7\u30e7\u30f3\u524a\u9664\u3057\u3066\u30ed\u30b0\u30a4\u30f3\u30da\u30fc\u30b8\u306b\u3068\u3070\u3059\r\n        $_SESSION = array();\r\n        setcookie(\"PHPSESSID\", '', time() - 1800, '\/');\r\n        setcookie(\"authchallenge\", '', time() - 1800, '\/');\r\n        session_destroy();\r\n        header('Location:login.php');\r\n        exit();\r\n    }\r\n\r\n}\r\n?&gt;<\/pre>\n<p>&nbsp;<\/p>\n<h2><strong>\u305d\u306e\u4ed6<\/strong><\/h2>\n<p>pear\u3092\u4f7f\u3063\u3066\u3044\u308b\u3068\u52d5\u304f\u3053\u3068\u306f\u52d5\u304f\u3051\u3069STRICT\u30a8\u30e9\u30fc\u307f\u305f\u3044\u306a\u30a8\u30e9\u30fc\u8868\u793a\u304c\u51fa\u308b\u3053\u3068\u304c\u3042\u308b\u3002\u4ee5\u4e0b\u3067\u975e\u8868\u793a\u306b\u3059\u308b\u4e8b\u306f\u53ef\u80fd\u3002<\/p>\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\">ini_set('error_reporting', E_ALL &amp; ~E_NOTICE &amp; ~E_STRICT);\r\nini_set('display_errors',1);<\/pre>\n<p>\u30ed\u30b0\u30a4\u30f3\u30da\u30fc\u30b8\u306f\u53c2\u8003\u30bd\u30fc\u30b9\u304c\u305f\u304f\u3055\u3093\u3042\u3063\u305f\u306e\u3067\u554f\u984c\u306a\u304b\u3063\u305f\u3051\u3069\u3001\u5f15\u304d\u56de\u3057\u305f\u3044\u30da\u30fc\u30b8\u304c\u3042\u307e\u308a\u898b\u3064\u304b\u3089\u305a\u82e6\u6226\u3057\u305f\u3002\u5927\u62b5\u306e\u30da\u30fc\u30b8\u306f\u975e\u30ed\u30b0\u30a4\u30f3\u3067\u3082\u95b2\u89a7\u3067\u304d\u3001\u4f8b\u3048\u3070\u30a2\u30ab\u30a6\u30f3\u30c8\u60c5\u5831\u5909\u66f4\u306e\u3088\u3046\u306a\u30ed\u30b0\u30a4\u30f3\u5fc5\u9808\u306e\u30da\u30fc\u30b8\u304c\u3042\u308b\u3088\u3046\u306a\u69cb\u6210\u306e\u5834\u5408\u306f\u3001checkUserLogin\u3092Class\u306e\u30b3\u30f3\u30b9\u30c8\u30e9\u30af\u30bf\u3068\u304b\u3067\u5b9f\u884c\u3057\u3066\u304a\u3044\u3066\u3001<\/p>\n<ul>\n<li>\u975e\u30ed\u30b0\u30a4\u30f3\u3067\u3082\u95b2\u89a7\u53ef\u2192\u30bd\u30fc\u30b9\u306echeckUserLogin\u306e\u95a2\u6570\u3067\u591a\u5206\u5927\u4e08\u592b\u3002<\/li>\n<li>\u30ed\u30b0\u30a4\u30f3\u5fc5\u9808\u2192\u4e88\u3081\u30ed\u30b0\u30a2\u30a6\u30c8\u30da\u30fc\u30b8\u3092\u4f5c\u3063\u3066\u304a\u3044\u3066checkUserLogin\u3067false\u304c\u8fd4\u3063\u305f\u5834\u5408\u306f\u305d\u3061\u3089\u306b\u9077\u79fb\u3055\u305b\u308b<\/li>\n<\/ul>\n<p>\u65b9\u6cd5\u3067\u4e00\u5fdc\u52d5\u304f\u3053\u3068\u306f\u52d5\u3044\u305f\u3002<\/p>\n","protected":false},"excerpt":{"rendered":"<p>PHP\u306e\u30b7\u30b9\u30c6\u30e0\u3067\u3042\u308b\u7a0b\u5ea6\u3061\u3083\u3093\u3068\u3057\u305f\u30ed\u30b0\u30a4\u30f3\u30b7\u30b9\u30c6\u30e0\u304c\u5fc5\u8981\u306b\u306a\u3063\u305f\u3002\u4eca\u307e\u3067\u30ed\u30b0 ... <\/p>\n","protected":false},"author":1,"featured_media":1085,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"_acf_changed":false,"footnotes":""},"categories":[2],"tags":[],"class_list":["post-2465","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-php"],"acf":[],"aioseo_notices":[],"_links":{"self":[{"href":"https:\/\/taitan916.info\/blog\/wp-json\/wp\/v2\/posts\/2465","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/taitan916.info\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/taitan916.info\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/taitan916.info\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/taitan916.info\/blog\/wp-json\/wp\/v2\/comments?post=2465"}],"version-history":[{"count":0,"href":"https:\/\/taitan916.info\/blog\/wp-json\/wp\/v2\/posts\/2465\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/taitan916.info\/blog\/wp-json\/wp\/v2\/media\/1085"}],"wp:attachment":[{"href":"https:\/\/taitan916.info\/blog\/wp-json\/wp\/v2\/media?parent=2465"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/taitan916.info\/blog\/wp-json\/wp\/v2\/categories?post=2465"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/taitan916.info\/blog\/wp-json\/wp\/v2\/tags?post=2465"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}