{"id":896,"date":"2019-04-13T23:14:33","date_gmt":"2019-04-13T14:14:33","guid":{"rendered":"https:\/\/www.nblog09.com\/w\/?p=896"},"modified":"2021-11-11T17:38:35","modified_gmt":"2021-11-11T08:38:35","slug":"django-encrypt","status":"publish","type":"post","link":"https:\/\/www.nblog09.com\/w\/2019\/04\/13\/django-encrypt\/","title":{"rendered":"Django\u306bbcrypt, argon2\u306e\u5c0e\u5165\u3057\u3001\u6697\u53f7\u5316\u8a2d\u5b9a\u3092\u3057\u3066\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u54c1\u8cea\u5f37\u5316\u3057\u3088\u3046"},"content":{"rendered":"<p><span style=\"font-size: 1em; letter-spacing: 0.05em;\">\u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u306b\u30d1\u30b9\u30ef\u30fc\u30c9\u3092\u4fdd\u5b58\u3059\u308b\u3068\u304d\u3001\u6697\u53f7\u5316\u304c\u5fc5\u8981\u3067\u3042\u308b\u3002Django\u3067\u306f\u3001\u30c7\u30d5\u30a9\u30eb\u30c8\u3067\u69d8\u3005\u306a\u6697\u53f7\u5316\u30a2\u30eb\u30b4\u30ea\u30ba\u30e0\u304c\u7528\u610f\u3055\u308c\u3066\u3044\u308b\u304c\u3001\u8ffd\u52a0\u3067\u3088\u308a\u5f37\u529b\u306a\u6697\u53f7\u5316\u30a2\u30eb\u30b4\u30ea\u30ba\u30e0\u3092\u7528\u3044\u308b\u3053\u3068\u3082\u3067\u304d\u308b\u3002<\/span><\/p>\n<p>\u6700\u3082\u5f37\u529b\u306a\u6697\u53f7\u5316\u30a2\u30eb\u30b4\u30ea\u30ba\u30e0\u3068\u3057\u3066\u3001<span class=\"pink_span\">bcript,argon2<\/span>\u304c\u3042\u308b\u3002<\/p>\n<p>\u4eca\u56de\u306f\u305d\u306e\u30a2\u30eb\u30b4\u30ea\u30ba\u30e0\u306e\u6982\u8981\u3068\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3001\u5c0e\u5165\u65b9\u6cd5\u306b\u3064\u3044\u3066\u7d39\u4ecb\u3059\u308b\u3002<\/p>\n<h2 class=\"title-border\"><strong><br \/>\nbcrypt,argon2\u306e\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb<br \/>\n<\/strong><\/h2>\n<ul>\n<li><a href=\"https:\/\/liginc.co.jp\/377191\">\u3053\u3061\u3089\u306e\u8a18\u4e8b<\/a>\u306b\u8a73\u7d30\u306b\u8a18\u8ff0\u3055\u308c\u3066\u3044\u308b\u304c\u3001bcrypt\u306f\u3001\u300c<strong>\u30cf\u30c3\u30b7\u30e5\u5316<\/strong>\u300d\u300c<strong>salt\u306e\u4ed8\u52a0<\/strong>\u300d\u300c<strong>\u30b9\u30c8\u30ec\u30c3\u30c1\u30f3\u30b0<\/strong>\u300d\u3068\u3044\u3046\u6a5f\u80fd\u3092\u6301\u3063\u305f\u6700\u3082\u5f37\u529b\u306a\u6697\u53f7\u5316\u30a2\u30eb\u30b4\u30ea\u30ba\u30e0\u306e\u4e00\u3064\u3067\u3042\u308b\u3002\u4ee5\u4e0b\u306e\u30b3\u30de\u30f3\u30c9\u3067\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3067\u304d\u308b\u3002<\/li>\n<p><span class=\"pink_span\"><br \/>\npip install bcrypt # bcrypt\u306e\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb<br \/>\n<\/span>\n<\/ul>\n<ul>\n<li>argon2\u306f2015\u5e74\u306ePassword Hashing Competition\u306eWinner\u3068\u306a\u3063\u305f\u30d1\u30b9\u30ef\u30fc\u30c9\u30cf\u30c3\u30b7\u30e5\u30a2\u30eb\u30b4\u30ea\u30ba\u30e0\u3067\u3042\u308a\u3001\u8a73\u7d30\u306b\u3064\u3044\u3066\u306f\u3001<a href=\"http:\/\/mikanmarusan.hatenablog.com\/entry\/2017\/12\/22\/125252\">\u3053\u3061\u3089<\/a>\u306b\u8a18\u8ff0\u3055\u308c\u3066\u3044\u308b\u3002<\/li>\n<p><span class=\"pink_span\"><br \/>\npip install django[argon2] # argon2\u306e\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb<br \/>\n<\/span>\n<\/ul>\n<p>\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3057\u305f\u3089\u3001\u6b21\u306b\u3053\u308c\u3092Django\u306e\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306b\u9069\u7528\u3059\u308b\u3088\u3046\u306bsettings.py\u3092\u8a2d\u5b9a\u3059\u308b\u3002<\/p>\n<h2 class=\"title-border\"><strong><br \/>\nDjango\u306e\u6697\u53f7\u5316\u30a2\u30eb\u30b4\u30ea\u30ba\u30e0\u306e\u8a2d\u5b9a<br \/>\n<\/strong><\/h2>\n<p>settings.py\u306e\u8a2d\u5b9a\u3092\u884c\u3046\u3002<\/p>\n<ul>\n<li>settings.py\u306b\u306f\u3001\u307e\u305a<span style=\"color: #ff0000;\">INSTALLED_APPS<\/span>\u306b<span class=\"pink_span\">django.contrib.admin, django.contrib.auth, django.contrib.contenttype<\/span>\u306e\uff13\u3064\u306e\u8a2d\u5b9a\u304c\u5165\u3063\u3066\u3044\u308b\u3053\u3068\u3092\u78ba\u8a8d\u3059\u308b\uff08\u30c7\u30d5\u30a9\u30eb\u30c8\u3067\u5165\u3063\u3066\u3044\u308b\u304c\u3001\u3082\u3057\u4f55\u3089\u304b\u306e\u4f5c\u696d\u3067\u6d88\u3057\u3066\u3057\u307e\u3063\u305f\u306e\u306a\u3089\u3001\u8ffd\u52a0\u3067\u5165\u308c\u308b\u3088\u3046\u306b\u3059\u308b\uff09<\/li>\n<li>\u6b21\u306b\u3001settings.py\u306b<span class=\"pink_span\">PASSWORD_HASHERS<\/span>\u306e\u8a2d\u5b9a\u3092\u8ffd\u52a0\u3059\u308b\u3002\u8a73\u7d30\u306f<a href=\"https:\/\/docs.djangoproject.com\/ja\/3.2\/ref\/settings\/#auth-password-validators\">\u3053\u3061\u3089\u306e\u30b5\u30a4\u30c8<\/a>\u306b\u8a18\u8f09\u3055\u308c\u3066\u3044\u308b\u304c\u3001settings.py\u306eAUTH_PASSWORD_VALIDATORS\u306e\u4e0a\u306b\u3001<span class=\"pink_span\">PASSWORD_HASHERS<\/span>\u3068\u3057\u3066\u3001\u914d\u5217\u3092\u8ffd\u52a0\u3059\u308b\u3002<\/li>\n<\/ul>\n<div class=\"programming-gray\">\n<ul>\n<li>settings.py<\/li>\n<\/ul>\n<div class=\"programming-inside\">\n<strong># \u4f7f\u7528\u3059\u308b\u6697\u53f7\u5316\u30a2\u30eb\u30b4\u30ea\u30ba\u30e0\u306e\u8a2d\u5b9a<\/strong><br \/>\n<strong># \u4e0a\u304b\u3089\u9806\u306b\u3001\u30e9\u30a4\u30d6\u30e9\u30ea\u304c\u5b58\u5728\u3059\u308b\u3082\u306e\u304c\u5229\u7528\u3055\u308c\u308b\u3002\u4e0b\u306e\u4f8b\u3067\u306f\u3001Argon2\u304c\u5b58\u5728\u3059\u308c\u3070Argon2\u304c\u4f7f\u308f\u308c\u306a\u3051\u308c\u3070BcryptSHA256\u304c\u5229\u7528\u3055\u308c\u308b<\/strong><br \/>\nPASSWORD_HASHERS = [<br \/>\n&nbsp;&nbsp;&nbsp;&nbsp;'django.contrib.auth.hashers.Argon2PasswordHasher',<br \/>\n&nbsp;&nbsp;&nbsp;&nbsp;'django.contrib.auth.hashers.BCryptSHA256PasswordHasher',<br \/>\n&nbsp;&nbsp;&nbsp;&nbsp;'django.contrib.auth.hashers.BCryptPasswordHasher',<br \/>\n&nbsp;&nbsp;&nbsp;&nbsp;'django.contrib.auth.hashers.PBKDF2PasswordHasher',<br \/>\n&nbsp;&nbsp;&nbsp;&nbsp;'django.contrib.auth.hashers.PBKDF2SHA1PasswordHasher',<br \/>\n]\n<\/div>\n<p>settings.py\u3092\u8a2d\u5b9a\u3057\u305f\u5f8c\u306b\u3001\u30d1\u30b9\u30ef\u30fc\u30c9\u3092\u767b\u9332\u3059\u308b<br \/>\n\u7ba1\u7406\u753b\u9762\u304b\u3089\u78ba\u8a8d\u3059\u308b\u3068\u3001\u30d1\u30b9\u30ef\u30fc\u30c9\u304cArgon2\u3067\u6697\u53f7\u5316\u3055\u308c\u3066\u3044\u308b\u3053\u3068\u304c\u8a18\u8f09\u3055\u308c\u3066\u3044\u308b\u3053\u3068\u304c\u308f\u304b\u308b\u3002<\/p>\n<ul>\n<li>\u7ba1\u7406\u753b\u9762<\/li>\n<\/ul>\n<p><img loading=\"lazy\" decoding=\"async\" class=\" wp-image-902 aligncenter\" src=\"https:\/\/www.nblog09.com\/w\/wp-content\/uploads\/2019\/04\/password-300x180.png\" alt=\"\" width=\"390\" height=\"234\" srcset=\"https:\/\/www.nblog09.com\/w\/wp-content\/uploads\/2019\/04\/password-300x180.png 300w, https:\/\/www.nblog09.com\/w\/wp-content\/uploads\/2019\/04\/password-768x460.png 768w, https:\/\/www.nblog09.com\/w\/wp-content\/uploads\/2019\/04\/password-1024x614.png 1024w, https:\/\/www.nblog09.com\/w\/wp-content\/uploads\/2019\/04\/password.png 1392w\" sizes=\"auto, (max-width: 390px) 100vw, 390px\" \/>\n<\/div>\n<p>\u4ee5\u4e0a\u3001Django\u3067Argon2\u3084Bcrypt\u306a\u3069\u306e\u5f37\u529b\u306a\u30a2\u30eb\u30b4\u30ea\u30ba\u30e0\u3092\u7528\u3044\u3066\u6697\u53f7\u5316\u3059\u308b\u65b9\u6cd5\u306b\u3064\u3044\u3066\u8a18\u8f09\u3057\u307e\u3057\u305f\u3002<\/p>\n<div class=\"django-adsense\"><\/div>\n","protected":false},"excerpt":{"rendered":"<p>\u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u306b\u30d1\u30b9\u30ef\u30fc\u30c9\u3092\u4fdd\u5b58\u3059\u308b\u3068\u304d\u3001\u6697\u53f7\u5316\u304c\u5fc5\u8981\u3067\u3042\u308b\u3002Django\u3067\u306f\u3001\u30c7\u30d5\u30a9\u30eb\u30c8\u3067\u69d8\u3005\u306a\u6697\u53f7\u5316\u30a2\u30eb\u30b4\u30ea\u30ba\u30e0\u304c\u7528\u610f\u3055\u308c\u3066\u3044\u308b\u304c\u3001\u8ffd\u52a0\u3067\u3088\u308a\u5f37\u529b\u306a\u6697\u53f7\u5316\u30a2\u30eb\u30b4\u30ea\u30ba\u30e0\u3092\u7528\u3044\u308b\u3053\u3068\u3082\u3067\u304d\u308b\u3002 \u6700\u3082\u5f37\u529b\u306a\u6697\u53f7\u5316\u30a2\u30eb\u30b4\u30ea\u30ba\u30e0 [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":354,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"om_disable_all_campaigns":false,"_uag_custom_page_level_css":"","_uf_show_specific_survey":0,"_uf_disable_surveys":false,"_genesis_hide_title":false,"_genesis_hide_breadcrumbs":false,"_genesis_hide_singular_image":false,"_genesis_hide_footer_widgets":false,"_genesis_custom_body_class":"","_genesis_custom_post_class":"","_genesis_layout":"","footnotes":""},"categories":[121,219],"tags":[153,154,143,14,155],"class_list":{"0":"post-896","1":"post","2":"type-post","3":"status-publish","4":"format-standard","5":"has-post-thumbnail","7":"category-django","8":"category-it-programming","9":"tag-argon2","10":"tag-bcrypt","11":"tag-form","12":"tag-python","13":"tag-security","14":"entry"},"uagb_featured_image_src":{"full":["https:\/\/www.nblog09.com\/w\/wp-content\/uploads\/2018\/12\/christmas-2975401__480.png",709,480,false],"thumbnail":["https:\/\/www.nblog09.com\/w\/wp-content\/uploads\/2018\/12\/christmas-2975401__480-150x150.png",150,150,true],"medium":["https:\/\/www.nblog09.com\/w\/wp-content\/uploads\/2018\/12\/christmas-2975401__480-300x203.png",300,203,true],"medium_large":["https:\/\/www.nblog09.com\/w\/wp-content\/uploads\/2018\/12\/christmas-2975401__480.png",709,480,false],"large":["https:\/\/www.nblog09.com\/w\/wp-content\/uploads\/2018\/12\/christmas-2975401__480.png",709,480,false],"1536x1536":["https:\/\/www.nblog09.com\/w\/wp-content\/uploads\/2018\/12\/christmas-2975401__480.png",709,480,false],"2048x2048":["https:\/\/www.nblog09.com\/w\/wp-content\/uploads\/2018\/12\/christmas-2975401__480.png",709,480,false],"home-middle":["https:\/\/www.nblog09.com\/w\/wp-content\/uploads\/2018\/12\/christmas-2975401__480.png",517,350,false],"home-top":["https:\/\/www.nblog09.com\/w\/wp-content\/uploads\/2018\/12\/christmas-2975401__480.png",620,420,false],"sidebar-thumbnail":["https:\/\/www.nblog09.com\/w\/wp-content\/uploads\/2018\/12\/christmas-2975401__480.png",100,68,false]},"uagb_author_info":{"display_name":"9nmatsumoto","author_link":"https:\/\/www.nblog09.com\/w\/author\/9nmatsumoto\/"},"uagb_comment_info":0,"uagb_excerpt":"\u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u306b\u30d1\u30b9\u30ef\u30fc\u30c9\u3092\u4fdd\u5b58\u3059\u308b\u3068\u304d\u3001\u6697\u53f7\u5316\u304c\u5fc5\u8981\u3067\u3042\u308b\u3002Django\u3067\u306f\u3001\u30c7\u30d5\u30a9\u30eb\u30c8\u3067\u69d8\u3005\u306a\u6697\u53f7\u5316\u30a2\u30eb\u30b4\u30ea&hellip;","_links":{"self":[{"href":"https:\/\/www.nblog09.com\/w\/wp-json\/wp\/v2\/posts\/896","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.nblog09.com\/w\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.nblog09.com\/w\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.nblog09.com\/w\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/www.nblog09.com\/w\/wp-json\/wp\/v2\/comments?post=896"}],"version-history":[{"count":15,"href":"https:\/\/www.nblog09.com\/w\/wp-json\/wp\/v2\/posts\/896\/revisions"}],"predecessor-version":[{"id":3795,"href":"https:\/\/www.nblog09.com\/w\/wp-json\/wp\/v2\/posts\/896\/revisions\/3795"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/www.nblog09.com\/w\/wp-json\/wp\/v2\/media\/354"}],"wp:attachment":[{"href":"https:\/\/www.nblog09.com\/w\/wp-json\/wp\/v2\/media?parent=896"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.nblog09.com\/w\/wp-json\/wp\/v2\/categories?post=896"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.nblog09.com\/w\/wp-json\/wp\/v2\/tags?post=896"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}