{"id":49592,"date":"2023-07-08T00:24:36","date_gmt":"2023-11-15T07:11:44","guid":{"rendered":"https:\/\/www.silicloud.com\/zh\/blog\/%e3%80%90python%e3%80%91%e3%80%90django%e3%80%91%e6%a3%80%e6%b5%8bcsrf%e4%bb%a4%e7%89%8c%e9%94%99%e8%af%af%e7%9a%84%e6%b5%8b%e8%af%95\/"},"modified":"2024-04-30T12:32:04","modified_gmt":"2024-04-30T04:32:04","slug":"%e3%80%90python%e3%80%91%e3%80%90django%e3%80%91%e6%a3%80%e6%b5%8bcsrf%e4%bb%a4%e7%89%8c%e9%94%99%e8%af%af%e7%9a%84%e6%b5%8b%e8%af%95","status":"publish","type":"post","link":"https:\/\/www.silicloud.com\/zh\/blog\/%e3%80%90python%e3%80%91%e3%80%90django%e3%80%91%e6%a3%80%e6%b5%8bcsrf%e4%bb%a4%e7%89%8c%e9%94%99%e8%af%af%e7%9a%84%e6%b5%8b%e8%af%95\/","title":{"rendered":"\u3010Python\u3011\u3010Django\u3011\u68c0\u6d4bCSRF\u4ee4\u724c\u9519\u8bef\u7684\u6d4b\u8bd5"},"content":{"rendered":"<h1>\u603b\u7ed3<\/h1>\n<p>\u6709\u65f6\u624b\u52a8\u521b\u5efaDjango\u6a21\u677f\u8868\u5355\u65f6\u4f1a\u72af\u4e00\u4e2a\u9519\u8bef\uff0c\u90a3\u5c31\u662f\u5fd8\u8bb0\u6dfb\u52a0CSRF\u4ee4\u724c\u6807\u7b7e\u3002\u901a\u5e38\u901a\u8fc7\u5728runserver\u4e2d\u8fd0\u884c\u6d4b\u8bd5\u73af\u5883\u6765\u68c0\u6d4b\uff0c\u4f46\u6211\u5c1d\u8bd5\u786e\u8ba4\u5728\u5355\u5143\u6d4b\u8bd5\u4e2d\u662f\u5426\u53ef\u4ee5\u68c0\u6d4b\u5230\u8fd9\u4e2a\u9519\u8bef\u3002<\/p>\n<h1>\u76ee\u5f55<\/h1>\n<ol>\n<li style=\"list-style-type: none;\">\n<ol>\u6e90\u4ee3\u7801<\/ol>\n<\/li>\n<\/ol>\n<p>&nbsp;<\/p>\n<ol>\n<li style=\"list-style-type: none;\">\n<ol>\u793a\u4f8b\u5e94\u7528\u7a0b\u5e8f<\/ol>\n<\/li>\n<\/ol>\n<p>&nbsp;<\/p>\n<ol>\n<li style=\"list-style-type: none;\">\n<ol>\u914d\u7f6e\uff08\u9879\u76ee\u8bbe\u7f6e\uff09<\/ol>\n<\/li>\n<\/ol>\n<p>&nbsp;<\/p>\n<ol>\n<li style=\"list-style-type: none;\">\n<ol>\u6d4b\u8bd5<\/ol>\n<\/li>\n<\/ol>\n<p>&nbsp;<\/p>\n<ol>\n<li style=\"list-style-type: none;\">\n<ol>\u6d4b\u8bd5\u6267\u884c\u7ed3\u679c<\/ol>\n<\/li>\n<\/ol>\n<p>&nbsp;<\/p>\n<ol>\n<li style=\"list-style-type: none;\">\n<ol>\u83b7\u5f97\u7684\u89c1\u89e3<\/ol>\n<\/li>\n<\/ol>\n<p>&nbsp;<\/p>\n<ol>\u518d\u8fdb\u4e00\u6b65<\/ol>\n<h1>\u8bf7\u5c06\u4ee5\u4e0b\u5185\u5bb9\u4ee5\u4e2d\u6587\u672c\u5730\u8bed\u8a00\u6539\u5199\uff1a<\/h1>\n<p>\u6e90\u4ee3\u7801<\/p>\n<p>\u5728Django\u6d4b\u8bd5\u6846\u67b6\u4e2d\uff0c\u68c0\u6d4b\u5230CSRF\u4ee4\u724c\u9519\u8bef\u3002<\/p>\n<p>config<\/p>\n<p>\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u8a2d\u5b9a<\/p>\n<p>sample<\/p>\n<p>\u30d5\u30a9\u30fc\u30e0\u3067\u5165\u529b\u3057\u305f\u30e1\u30c3\u30bb\u30fc\u30b8\u3092\u4fdd\u5b58\u3059\u308b\u3060\u3051\u306e\u30b5\u30f3\u30d7\u30eb\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3<\/p>\n<p>templates<\/p>\n<p>HTML\u30c6\u30f3\u30d7\u30ec\u30fc\u30c8<\/p>\n<p>tests<\/p>\n<p>\u30e6\u30cb\u30c3\u30c8\u30c6\u30b9\u30c8<br \/>\nsample\uff1adjango.test.testcases.TestCase\u3092\u7528\u3044\u305f\u30c6\u30b9\u30c8<br \/>\ne2e\uff1adjango.test.testcases.LiveServerTestCase\u3068Selenium WebDriver\u3092\u7528\u3044\u305f\u30c6\u30b9\u30c8<\/p>\n<h2>\u793a\u4f8b\u5e94\u7528\u7a0b\u5e8f<\/h2>\n<h3>\u6837\u4f8b\u6a21\u578b\/sample\/models.py<\/h3>\n<p>\u8fd9\u4e2a\u6a21\u578b\u53ea\u662f\u7b80\u5355\u5730\u4fdd\u7559\u6d88\u606f\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"kn\">from<\/span> <span class=\"nn\">django.db<\/span> <span class=\"kn\">import<\/span> <span class=\"n\">models<\/span>\r\n\r\n<span class=\"c1\"># Create your models here.\r\n<\/span><span class=\"k\">class<\/span> <span class=\"nc\">Sample<\/span><span class=\"p\">(<\/span><span class=\"n\">models<\/span><span class=\"p\">.<\/span><span class=\"n\">Model<\/span><span class=\"p\">):<\/span>\r\n    <span class=\"n\">message<\/span> <span class=\"o\">=<\/span> <span class=\"n\">models<\/span><span class=\"p\">.<\/span><span class=\"n\">CharField<\/span><span class=\"p\">(<\/span><span class=\"n\">verbose_name<\/span><span class=\"o\">=<\/span><span class=\"s\">'\u30e1\u30c3\u30bb\u30fc\u30b8'<\/span><span class=\"p\">,<\/span> <span class=\"n\">max_length<\/span><span class=\"o\">=<\/span><span class=\"mi\">255<\/span><span class=\"p\">)<\/span>\r\n\r\n    <span class=\"s\">\"\"\"\u30b5\u30f3\u30d7\u30eb\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u30e2\u30c7\u30eb\"\"\"<\/span>\r\n    <span class=\"k\">class<\/span> <span class=\"nc\">Meta<\/span><span class=\"p\">:<\/span>\r\n        <span class=\"c1\"># \u30c6\u30fc\u30d6\u30eb\u540d\r\n<\/span>        <span class=\"n\">db_table<\/span> <span class=\"o\">=<\/span> <span class=\"s\">'sample'<\/span>\r\n<\/code><\/pre>\n<h3>\u8868\u5355\u6837\u672c\/\u8868\u5355.py<\/h3>\n<p>\u4f7f\u7528Python\u4e2d\u7684Django\u6846\u67b6\uff0c\u901a\u8fc7\u5728\u6837\u672c\/models.py\u6587\u4ef6\u4e2d\u5b9a\u4e49\u7684Sample\u6a21\u578b\u548cdjango.models.ModelForm\uff0c\u6765\u5b9a\u4e49\u7528\u4e8e\u6d88\u606f\u7684\u8868\u5355\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"kn\">from<\/span> <span class=\"nn\">django<\/span> <span class=\"kn\">import<\/span> <span class=\"n\">forms<\/span>\r\n<span class=\"kn\">from<\/span> <span class=\"nn\">.models<\/span> <span class=\"kn\">import<\/span> <span class=\"n\">Sample<\/span>\r\n\r\n<span class=\"k\">class<\/span> <span class=\"nc\">SampleForm<\/span><span class=\"p\">(<\/span><span class=\"n\">forms<\/span><span class=\"p\">.<\/span><span class=\"n\">ModelForm<\/span><span class=\"p\">):<\/span>\r\n    <span class=\"s\">\"\"\"\u30b5\u30f3\u30d7\u30eb\u30d5\u30a9\u30fc\u30e0\"\"\"<\/span>\r\n    <span class=\"k\">class<\/span> <span class=\"nc\">Meta<\/span><span class=\"p\">:<\/span>\r\n        <span class=\"n\">model<\/span> <span class=\"o\">=<\/span> <span class=\"n\">Sample<\/span>\r\n        <span class=\"n\">fields<\/span> <span class=\"o\">=<\/span> <span class=\"p\">(<\/span><span class=\"s\">'message'<\/span><span class=\"p\">,)<\/span>\r\n        <span class=\"n\">widgets<\/span> <span class=\"o\">=<\/span> <span class=\"p\">{<\/span>\r\n            <span class=\"s\">'message'<\/span><span class=\"p\">:<\/span> <span class=\"n\">forms<\/span><span class=\"p\">.<\/span><span class=\"n\">Textarea<\/span><span class=\"p\">(<\/span><span class=\"n\">attrs<\/span><span class=\"o\">=<\/span><span class=\"p\">{<\/span><span class=\"s\">'placeholder'<\/span><span class=\"p\">:<\/span> <span class=\"s\">'\u30e1\u30c3\u30bb\u30fc\u30b8'<\/span><span class=\"p\">})<\/span>\r\n        <span class=\"p\">}<\/span>\r\n<\/code><\/pre>\n<h3>\u67e5\u770b sample\/views.py<\/h3>\n<p>\u4f7f\u7528\u5728sample\/forms.py\u4e2d\u5b9a\u4e49\u7684SampleForm\uff0c\u6765\u5b9a\u4e49\u4e00\u4e2a\u89c6\u56fe\u7c7b\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"kn\">from<\/span> <span class=\"nn\">django.shortcuts<\/span> <span class=\"kn\">import<\/span> <span class=\"n\">render<\/span><span class=\"p\">,<\/span><span class=\"n\">redirect<\/span>\r\n<span class=\"kn\">from<\/span> <span class=\"nn\">.forms<\/span> <span class=\"kn\">import<\/span> <span class=\"n\">SampleForm<\/span>\r\n<span class=\"kn\">from<\/span> <span class=\"nn\">django.urls<\/span> <span class=\"kn\">import<\/span> <span class=\"n\">reverse<\/span>\r\n<span class=\"kn\">from<\/span> <span class=\"nn\">django.views<\/span> <span class=\"kn\">import<\/span> <span class=\"n\">View<\/span>\r\n\r\n<span class=\"k\">class<\/span> <span class=\"nc\">SampleFormView<\/span><span class=\"p\">(<\/span><span class=\"n\">View<\/span><span class=\"p\">):<\/span>\r\n\r\n    <span class=\"c1\"># Create your views here.\r\n<\/span>    <span class=\"k\">def<\/span> <span class=\"nf\">get<\/span><span class=\"p\">(<\/span><span class=\"bp\">self<\/span><span class=\"p\">,<\/span> <span class=\"n\">request<\/span><span class=\"p\">,<\/span> <span class=\"o\">*<\/span><span class=\"n\">args<\/span><span class=\"p\">,<\/span> <span class=\"o\">**<\/span><span class=\"n\">kwargs<\/span><span class=\"p\">):<\/span>\r\n        <span class=\"n\">context<\/span> <span class=\"o\">=<\/span> <span class=\"p\">{<\/span>\r\n            <span class=\"s\">'form'<\/span><span class=\"p\">:<\/span> <span class=\"n\">SampleForm<\/span><span class=\"p\">()<\/span>\r\n        <span class=\"p\">}<\/span>\r\n        <span class=\"k\">return<\/span> <span class=\"n\">render<\/span><span class=\"p\">(<\/span><span class=\"n\">request<\/span><span class=\"p\">,<\/span> <span class=\"s\">'sample\/index.html'<\/span><span class=\"p\">,<\/span> <span class=\"n\">context<\/span><span class=\"p\">)<\/span>\r\n\r\n    <span class=\"k\">def<\/span> <span class=\"nf\">post<\/span><span class=\"p\">(<\/span><span class=\"bp\">self<\/span><span class=\"p\">,<\/span> <span class=\"n\">request<\/span><span class=\"p\">,<\/span> <span class=\"o\">*<\/span><span class=\"n\">args<\/span><span class=\"p\">,<\/span> <span class=\"o\">**<\/span><span class=\"n\">kwargs<\/span><span class=\"p\">):<\/span>\r\n        <span class=\"n\">form<\/span> <span class=\"o\">=<\/span> <span class=\"n\">SampleForm<\/span><span class=\"p\">(<\/span><span class=\"n\">request<\/span><span class=\"p\">.<\/span><span class=\"n\">POST<\/span><span class=\"p\">)<\/span>\r\n        <span class=\"k\">if<\/span> <span class=\"n\">form<\/span><span class=\"p\">.<\/span><span class=\"n\">is_valid<\/span><span class=\"p\">():<\/span>\r\n            <span class=\"n\">form<\/span><span class=\"p\">.<\/span><span class=\"n\">save<\/span><span class=\"p\">()<\/span>\r\n            <span class=\"k\">return<\/span> <span class=\"n\">redirect<\/span><span class=\"p\">(<\/span><span class=\"n\">reverse<\/span><span class=\"p\">(<\/span><span class=\"s\">'sample:index'<\/span><span class=\"p\">))<\/span>\r\n\r\n        <span class=\"n\">context<\/span> <span class=\"o\">=<\/span> <span class=\"p\">{<\/span>\r\n            <span class=\"s\">'form'<\/span><span class=\"p\">:<\/span> <span class=\"n\">form<\/span>\r\n        <span class=\"p\">}<\/span>\r\n        <span class=\"k\">return<\/span> <span class=\"n\">render<\/span><span class=\"p\">(<\/span><span class=\"n\">request<\/span><span class=\"p\">,<\/span> <span class=\"s\">'sample\/index.html'<\/span><span class=\"p\">,<\/span> <span class=\"n\">context<\/span><span class=\"p\">)<\/span>\r\n\r\n<span class=\"n\">sampleFromView<\/span> <span class=\"o\">=<\/span> <span class=\"n\">SampleFormView<\/span><span class=\"p\">.<\/span><span class=\"n\">as_view<\/span><span class=\"p\">()<\/span>\r\n<\/code><\/pre>\n<h3>HTML\u6a21\u677f templates\/sample\/index.py<\/h3>\n<p>\u53ea\u9700\u663e\u793a\u8f93\u5165\u8868\u5355\u548c\u201c\u63d0\u4ea4\u201d\u63d0\u4ea4\u6309\u94ae\u3002<br \/>\n\u8fd9\u6b21\u662f\u4e3a\u4e86\u6d4b\u8bd5CSRF\u4ee4\u724c\u9519\u8bef\uff0c\u6545\u610f\u53bb\u9664\u4e86{{ csrf_token }}\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"cp\">&lt;!DOCTYPE html&gt;<\/span>\r\n<span class=\"nt\">&lt;html<\/span> <span class=\"na\">lang=<\/span><span class=\"s\">\"ja\"<\/span><span class=\"nt\">&gt;<\/span>\r\n    <span class=\"nt\">&lt;head&gt;<\/span>\r\n        <span class=\"nt\">&lt;meta<\/span> <span class=\"na\">charset=<\/span><span class=\"s\">\"UTF-8\"<\/span><span class=\"nt\">&gt;<\/span>\r\n        <span class=\"nt\">&lt;title&gt;<\/span>Form Sample<span class=\"nt\">&lt;\/title&gt;<\/span>\r\n    <span class=\"nt\">&lt;\/head&gt;<\/span>\r\n    <span class=\"nt\">&lt;body&gt;<\/span>\r\n        <span class=\"nt\">&lt;form<\/span> <span class=\"na\">method=<\/span><span class=\"s\">\"POST\"<\/span> <span class=\"na\">action=<\/span><span class=\"s\">\"{% url 'sample:index' %}\"<\/span><span class=\"nt\">&gt;<\/span>\r\n            {% for field in form %}\r\n            <span class=\"nt\">&lt;label&gt;<\/span>{{ field.label_tag }}<span class=\"nt\">&lt;\/label&gt;<\/span>\r\n            {{ field }}\r\n            {% endfor %}\r\n            <span class=\"nt\">&lt;input<\/span> <span class=\"na\">type=<\/span><span class=\"s\">\"submit\"<\/span> <span class=\"na\">value=<\/span><span class=\"s\">\"\u9001\u4fe1\"<\/span> <span class=\"nt\">\/&gt;<\/span>\r\n        <span class=\"nt\">&lt;\/form&gt;<\/span>\r\n    <span class=\"nt\">&lt;\/body&gt;<\/span>\r\n<span class=\"nt\">&lt;\/html&gt;<\/span>\r\n<\/code><\/pre>\n<h3>\u5e94\u7528\u5185\u7684URL\u8bbe\u7f6e sample\/urls.py<\/h3>\n<p>\u5b9a\u7fa9\u8bbf\u95ee\u5df2\u521b\u5efa\u7684\u89c6\u56fe\u7c7b\u7684URL\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"kn\">from<\/span> <span class=\"nn\">django.urls<\/span> <span class=\"kn\">import<\/span> <span class=\"n\">path<\/span>\r\n<span class=\"kn\">from<\/span> <span class=\"nn\">.<\/span> <span class=\"kn\">import<\/span> <span class=\"n\">views<\/span>\r\n\r\n<span class=\"n\">app_name<\/span><span class=\"o\">=<\/span><span class=\"s\">'sample'<\/span>\r\n<span class=\"n\">urlpatterns<\/span> <span class=\"o\">=<\/span> <span class=\"p\">[<\/span>\r\n    <span class=\"n\">path<\/span><span class=\"p\">(<\/span><span class=\"s\">''<\/span><span class=\"p\">,<\/span> <span class=\"n\">views<\/span><span class=\"p\">.<\/span><span class=\"n\">sampleFromView<\/span><span class=\"p\">,<\/span> <span class=\"n\">name<\/span><span class=\"o\">=<\/span><span class=\"s\">\"index\"<\/span><span class=\"p\">)<\/span>\r\n<span class=\"p\">]<\/span>\r\n<\/code><\/pre>\n<h2>\u914d\u7f6e\uff08\u9879\u76ee\u8bbe\u7f6e\uff09<\/h2>\n<h3>\u9879\u76ee\u8bbe\u7f6e config\/settings.py<\/h3>\n<p>\u6211\u4f1a\u6dfb\u52a0\u4ee5\u4e0b\u8bbe\u7f6e\u3002<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">\u4f5c\u6210\u3057\u305fsample\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u3092\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3059\u308b<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">HTML\u30c6\u30f3\u30d7\u30ec\u30fc\u30c8\u3092\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u76f4\u4e0b\u306etemplates\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u304b\u3089\u8aad\u307f\u8fbc\u3080<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">\u8a00\u8a9e\u8a2d\u5b9a\u3092\u300c\u65e5\u672c\u8a9e\u300d\u306b\u8a2d\u5b9a\u3059\u308b<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\u30bf\u30a4\u30e0\u30be\u30fc\u30f3\u8a2d\u5b9a\u3092\u300c\u6771\u4eac\u300d\u306b\u8a2d\u5b9a\u3059\u308b<\/ul>\n<pre class=\"post-pre\"><code><span class=\"err\">\uff08<\/span><span class=\"n\">\u7701\u7565<\/span><span class=\"err\">\uff09<\/span>\r\n<span class=\"c1\"># Application definition\r\n<\/span>\r\n<span class=\"n\">INSTALLED_APPS<\/span> <span class=\"o\">=<\/span> <span class=\"p\">[<\/span>\r\n    <span class=\"s\">'django.contrib.admin'<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"s\">'django.contrib.auth'<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"s\">'django.contrib.contenttypes'<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"s\">'django.contrib.sessions'<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"s\">'django.contrib.messages'<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"s\">'django.contrib.staticfiles'<\/span><span class=\"p\">,<\/span>\r\n    <span class=\"s\">'sample'<\/span><span class=\"p\">,<\/span>\r\n<span class=\"p\">]<\/span>\r\n\r\n<span class=\"err\">\u2026\u2026<\/span>\r\n\r\n<span class=\"n\">TEMPLATES<\/span> <span class=\"o\">=<\/span> <span class=\"p\">[<\/span>\r\n    <span class=\"p\">{<\/span>\r\n        <span class=\"s\">'BACKEND'<\/span><span class=\"p\">:<\/span> <span class=\"s\">'django.template.backends.django.DjangoTemplates'<\/span><span class=\"p\">,<\/span>\r\n        <span class=\"s\">'DIRS'<\/span><span class=\"p\">:<\/span> <span class=\"p\">[<\/span>\r\n            <span class=\"n\">os<\/span><span class=\"p\">.<\/span><span class=\"n\">path<\/span><span class=\"p\">.<\/span><span class=\"n\">join<\/span><span class=\"p\">(<\/span><span class=\"n\">BASE_DIR<\/span><span class=\"p\">,<\/span> <span class=\"s\">'templates'<\/span><span class=\"p\">)<\/span>\r\n        <span class=\"p\">],<\/span>\r\n        <span class=\"s\">'APP_DIRS'<\/span><span class=\"p\">:<\/span> <span class=\"bp\">True<\/span><span class=\"p\">,<\/span>\r\n        <span class=\"s\">'OPTIONS'<\/span><span class=\"p\">:<\/span> <span class=\"p\">{<\/span>\r\n            <span class=\"s\">'context_processors'<\/span><span class=\"p\">:<\/span> <span class=\"p\">[<\/span>\r\n                <span class=\"s\">'django.template.context_processors.debug'<\/span><span class=\"p\">,<\/span>\r\n                <span class=\"s\">'django.template.context_processors.request'<\/span><span class=\"p\">,<\/span>\r\n                <span class=\"s\">'django.contrib.auth.context_processors.auth'<\/span><span class=\"p\">,<\/span>\r\n                <span class=\"s\">'django.contrib.messages.context_processors.messages'<\/span><span class=\"p\">,<\/span>\r\n            <span class=\"p\">],<\/span>\r\n        <span class=\"p\">},<\/span>\r\n    <span class=\"p\">},<\/span>\r\n<span class=\"p\">]<\/span>\r\n\r\n<span class=\"err\">\u2026\u2026<\/span>\r\n\r\n<span class=\"c1\"># Internationalization\r\n# https:\/\/docs.djangoproject.com\/en\/2.2\/topics\/i18n\/\r\n<\/span>\r\n<span class=\"n\">LANGUAGE_CODE<\/span> <span class=\"o\">=<\/span> <span class=\"s\">'ja-JP'<\/span>\r\n\r\n<span class=\"n\">TIME_ZONE<\/span> <span class=\"o\">=<\/span> <span class=\"s\">'Asia\/Tokyo'<\/span>\r\n\r\n<span class=\"err\">\uff08<\/span><span class=\"n\">\u7701\u7565<\/span><span class=\"err\">\uff09<\/span>\r\n<\/code><\/pre>\n<h3>\u9879\u76ee\u7684URL\u8bbe\u7f6e config\/urls.py<\/h3>\n<p>\u6211\u5df2\u7ecf\u52a0\u8f7d\u4e86\u5728sample\u9879\u76ee\u4e2d\u521b\u5efa\u7684URL\u8bbe\u7f6e\uff0c\u5e76\u8fdb\u884c\u4e86\u914d\u7f6e\uff0c\u4ee5\u4fbf\u5728\u9996\u9875\u4e0a\u53ef\u4ee5\u8bbf\u95ee\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"kn\">from<\/span> <span class=\"nn\">django.contrib<\/span> <span class=\"kn\">import<\/span> <span class=\"n\">admin<\/span>\r\n<span class=\"kn\">from<\/span> <span class=\"nn\">django.urls<\/span> <span class=\"kn\">import<\/span> <span class=\"n\">path<\/span><span class=\"p\">,<\/span> <span class=\"n\">include<\/span>\r\n\r\n<span class=\"n\">urlpatterns<\/span> <span class=\"o\">=<\/span> <span class=\"p\">[<\/span>\r\n    <span class=\"n\">path<\/span><span class=\"p\">(<\/span><span class=\"s\">'admin\/'<\/span><span class=\"p\">,<\/span> <span class=\"n\">admin<\/span><span class=\"p\">.<\/span><span class=\"n\">site<\/span><span class=\"p\">.<\/span><span class=\"n\">urls<\/span><span class=\"p\">),<\/span>\r\n    <span class=\"n\">path<\/span><span class=\"p\">(<\/span><span class=\"s\">''<\/span><span class=\"p\">,<\/span> <span class=\"n\">include<\/span><span class=\"p\">(<\/span><span class=\"s\">'sample.urls'<\/span><span class=\"p\">)),<\/span>\r\n<span class=\"p\">]<\/span>\r\n<\/code><\/pre>\n<h2>\u8003\u8bd5<\/h2>\n<h3>\u793a\u4f8b<\/h3>\n<p>\u6211\u5c06\u4f7f\u7528django.test.testcases.Testcase\u6765\u8fdb\u884c\u6d4b\u8bd5\u3002\u4e3a\u4e86\u8fdb\u884cCSRF\u4ee4\u724c\u7684\u68c0\u67e5\uff0c\u6211\u5c06\u91cd\u65b0\u8bbe\u7f6eself.client\u5bf9\u8c61\uff0c\u8be5\u5bf9\u8c61\u662fdjango.test.Client\u7c7b\u7684\u4e00\u4e2a\u5b9e\u4f8b\u3002\u6211\u4f1a\u6267\u884cGET\u548cPOST\u5728\u793a\u4f8b\u5e94\u7528\u7a0b\u5e8f\u4e2d\uff0c\u4ee5\u786e\u8ba4\u5728GET\u8bf7\u6c42\u65f6\uff0c\u6307\u5b9a\u7684\u6a21\u677f\u88ab\u6b63\u786e\u663e\u793a\uff0c\u5728POST\u8bf7\u6c42\u65f6\uff0cHTTP\u72b6\u6001\u7801\u53d8\u4e3a403\u3002<\/p>\n<p>\u53c2\u8003\u9875\u9762\uff1a<br \/>\n\u8bf7\u6c42\u7684\u521b\u5efa\uff1a\u6d4b\u8bd5\u5de5\u5177 | Django \u6587\u6863 | Django<br \/>\nSimpleTestCase\uff1adjango.test.testcases | Django \u6587\u6863 | Django<\/p>\n<h4>\u6d4b\u8bd5\/\u6837\u672c\/\u6d4b\u8bd5\u89c6\u56fe.py<\/h4>\n<pre class=\"post-pre\"><code><span class=\"kn\">from<\/span> <span class=\"nn\">django.test.testcases<\/span> <span class=\"kn\">import<\/span> <span class=\"n\">TestCase<\/span>\r\n<span class=\"kn\">from<\/span> <span class=\"nn\">django.urls<\/span> <span class=\"kn\">import<\/span> <span class=\"n\">reverse<\/span>\r\n<span class=\"kn\">from<\/span> <span class=\"nn\">django.test.client<\/span> <span class=\"kn\">import<\/span> <span class=\"n\">Client<\/span>\r\n\r\n<span class=\"k\">class<\/span> <span class=\"nc\">SampleViewTest<\/span><span class=\"p\">(<\/span><span class=\"n\">TestCase<\/span><span class=\"p\">):<\/span>\r\n\r\n    <span class=\"c1\"># def _pre_setup(self):\r\n<\/span>    <span class=\"c1\">#     super()._pre_setup()\r\n<\/span>    <span class=\"c1\">#     self.client = Client(enforce_csrf_checks=True)\r\n<\/span>\r\n    <span class=\"k\">def<\/span> <span class=\"nf\">setUp<\/span><span class=\"p\">(<\/span><span class=\"bp\">self<\/span><span class=\"p\">):<\/span>\r\n        <span class=\"nb\">super<\/span><span class=\"p\">().<\/span><span class=\"n\">setUp<\/span><span class=\"p\">()<\/span>\r\n        <span class=\"bp\">self<\/span><span class=\"p\">.<\/span><span class=\"n\">client<\/span> <span class=\"o\">=<\/span> <span class=\"n\">Client<\/span><span class=\"p\">(<\/span><span class=\"n\">enforce_csrf_checks<\/span><span class=\"o\">=<\/span><span class=\"bp\">True<\/span><span class=\"p\">)<\/span>\r\n\r\n    <span class=\"k\">def<\/span> <span class=\"nf\">test_get_index_01<\/span><span class=\"p\">(<\/span><span class=\"bp\">self<\/span><span class=\"p\">):<\/span>\r\n        <span class=\"n\">response<\/span> <span class=\"o\">=<\/span> <span class=\"bp\">self<\/span><span class=\"p\">.<\/span><span class=\"n\">client<\/span><span class=\"p\">.<\/span><span class=\"n\">get<\/span><span class=\"p\">(<\/span><span class=\"n\">reverse<\/span><span class=\"p\">(<\/span><span class=\"s\">'sample:index'<\/span><span class=\"p\">))<\/span>\r\n        <span class=\"bp\">self<\/span><span class=\"p\">.<\/span><span class=\"n\">assertTemplateUsed<\/span><span class=\"p\">(<\/span><span class=\"n\">response<\/span><span class=\"p\">,<\/span> <span class=\"s\">'sample\/index.html'<\/span><span class=\"p\">)<\/span>\r\n\r\n    <span class=\"k\">def<\/span> <span class=\"nf\">test_post_index_01<\/span><span class=\"p\">(<\/span><span class=\"bp\">self<\/span><span class=\"p\">):<\/span>\r\n        <span class=\"n\">response<\/span> <span class=\"o\">=<\/span> <span class=\"bp\">self<\/span><span class=\"p\">.<\/span><span class=\"n\">client<\/span><span class=\"p\">.<\/span><span class=\"n\">post<\/span><span class=\"p\">(<\/span><span class=\"n\">reverse<\/span><span class=\"p\">(<\/span><span class=\"s\">'sample:index'<\/span><span class=\"p\">),<\/span> <span class=\"n\">data<\/span><span class=\"o\">=<\/span><span class=\"p\">{})<\/span>\r\n        <span class=\"c1\"># If csrf_token was template given.\r\n<\/span>        <span class=\"c1\"># self.assertTemplateUsed(response, 'sample\/index.html')\r\n<\/span>        <span class=\"c1\"># If csrf_token was't template given.\r\n<\/span>        <span class=\"bp\">self<\/span><span class=\"p\">.<\/span><span class=\"n\">assertEquals<\/span><span class=\"p\">(<\/span><span class=\"mi\">403<\/span><span class=\"p\">,<\/span> <span class=\"n\">response<\/span><span class=\"p\">.<\/span><span class=\"n\">status_code<\/span><span class=\"p\">)<\/span>\r\n\r\n    <span class=\"k\">def<\/span> <span class=\"nf\">test_post_index_02<\/span><span class=\"p\">(<\/span><span class=\"bp\">self<\/span><span class=\"p\">):<\/span>\r\n        <span class=\"n\">response<\/span> <span class=\"o\">=<\/span> <span class=\"bp\">self<\/span><span class=\"p\">.<\/span><span class=\"n\">client<\/span><span class=\"p\">.<\/span><span class=\"n\">post<\/span><span class=\"p\">(<\/span><span class=\"n\">reverse<\/span><span class=\"p\">(<\/span><span class=\"s\">'sample:index'<\/span><span class=\"p\">),<\/span> <span class=\"n\">data<\/span><span class=\"o\">=<\/span><span class=\"p\">{<\/span><span class=\"s\">'message'<\/span><span class=\"p\">:<\/span> <span class=\"s\">'Test Message'<\/span><span class=\"p\">})<\/span>\r\n        <span class=\"c1\"># If csrf_token was template given.\r\n<\/span>        <span class=\"c1\"># self.assertRedirects(response, reverse('sample:index'))\r\n<\/span>        <span class=\"c1\"># If csrf_token was't template given.\r\n<\/span>        <span class=\"bp\">self<\/span><span class=\"p\">.<\/span><span class=\"n\">assertEquals<\/span><span class=\"p\">(<\/span><span class=\"mi\">403<\/span><span class=\"p\">,<\/span> <span class=\"n\">response<\/span><span class=\"p\">.<\/span><span class=\"n\">status_code<\/span><span class=\"p\">)<\/span>\r\n<\/code><\/pre>\n<h3>\u7aef\u5230\u7aef<\/h3>\n<p>\u6211\u4eec\u5c06\u4f7f\u7528Django.test.testcases.LiveServerTestCase\u548cSelenium WebDriver\u8fdb\u884c\u6d4b\u8bd5\u3002<\/p>\n<h4>\u6d4b\u8bd5\/e2e\/test_index.py<\/h4>\n<pre class=\"post-pre\"><code><span class=\"kn\">from<\/span> <span class=\"nn\">django.test.testcases<\/span> <span class=\"kn\">import<\/span> <span class=\"n\">LiveServerTestCase<\/span>\r\n<span class=\"kn\">import<\/span> <span class=\"nn\">chromedriver_binary<\/span>\r\n<span class=\"kn\">from<\/span> <span class=\"nn\">selenium<\/span> <span class=\"kn\">import<\/span> <span class=\"n\">webdriver<\/span>\r\n<span class=\"kn\">from<\/span> <span class=\"nn\">selenium.webdriver.chrome.options<\/span> <span class=\"kn\">import<\/span> <span class=\"n\">Options<\/span>\r\n<span class=\"kn\">from<\/span> <span class=\"nn\">selenium.webdriver.common.keys<\/span> <span class=\"kn\">import<\/span> <span class=\"n\">Keys<\/span>\r\n<span class=\"kn\">from<\/span> <span class=\"nn\">selenium.webdriver.support.ui<\/span> <span class=\"kn\">import<\/span> <span class=\"n\">WebDriverWait<\/span>\r\n<span class=\"kn\">from<\/span> <span class=\"nn\">selenium.webdriver.support<\/span> <span class=\"kn\">import<\/span> <span class=\"n\">expected_conditions<\/span> <span class=\"k\">as<\/span> <span class=\"n\">EC<\/span>\r\n\r\n<span class=\"k\">class<\/span> <span class=\"nc\">LiveServerIndexTest<\/span><span class=\"p\">(<\/span><span class=\"n\">LiveServerTestCase<\/span><span class=\"p\">):<\/span>\r\n    <span class=\"o\">@<\/span><span class=\"nb\">classmethod<\/span>\r\n    <span class=\"k\">def<\/span> <span class=\"nf\">setUpClass<\/span><span class=\"p\">(<\/span><span class=\"n\">cls<\/span><span class=\"p\">):<\/span>\r\n        <span class=\"nb\">super<\/span><span class=\"p\">().<\/span><span class=\"n\">setUpClass<\/span><span class=\"p\">()<\/span>\r\n        <span class=\"n\">options<\/span> <span class=\"o\">=<\/span> <span class=\"n\">Options<\/span><span class=\"p\">()<\/span>\r\n        <span class=\"n\">options<\/span><span class=\"p\">.<\/span><span class=\"n\">add_argument<\/span><span class=\"p\">(<\/span><span class=\"s\">'--headless'<\/span><span class=\"p\">)<\/span>\r\n        <span class=\"n\">cls<\/span><span class=\"p\">.<\/span><span class=\"n\">selenium<\/span> <span class=\"o\">=<\/span> <span class=\"n\">webdriver<\/span><span class=\"p\">.<\/span><span class=\"n\">Chrome<\/span><span class=\"p\">(<\/span><span class=\"n\">options<\/span><span class=\"o\">=<\/span><span class=\"n\">options<\/span><span class=\"p\">)<\/span>\r\n        <span class=\"n\">cls<\/span><span class=\"p\">.<\/span><span class=\"n\">selenium<\/span><span class=\"p\">.<\/span><span class=\"n\">implicitly_wait<\/span><span class=\"p\">(<\/span><span class=\"mi\">10<\/span><span class=\"p\">)<\/span>\r\n\r\n    <span class=\"k\">def<\/span> <span class=\"nf\">test_index_01<\/span><span class=\"p\">(<\/span><span class=\"bp\">self<\/span><span class=\"p\">):<\/span>\r\n        <span class=\"bp\">self<\/span><span class=\"p\">.<\/span><span class=\"n\">selenium<\/span><span class=\"p\">.<\/span><span class=\"n\">get<\/span><span class=\"p\">(<\/span><span class=\"s\">'%s%s'<\/span> <span class=\"o\">%<\/span> <span class=\"p\">(<\/span><span class=\"bp\">self<\/span><span class=\"p\">.<\/span><span class=\"n\">live_server_url<\/span><span class=\"p\">,<\/span> <span class=\"s\">'\/'<\/span><span class=\"p\">))<\/span>\r\n        <span class=\"bp\">self<\/span><span class=\"p\">.<\/span><span class=\"n\">assertTemplateUsed<\/span><span class=\"p\">(<\/span><span class=\"s\">'sample\/index.html'<\/span><span class=\"p\">)<\/span>\r\n        <span class=\"bp\">self<\/span><span class=\"p\">.<\/span><span class=\"n\">assertEquals<\/span><span class=\"p\">(<\/span><span class=\"s\">'Form Sample'<\/span><span class=\"p\">,<\/span> <span class=\"bp\">self<\/span><span class=\"p\">.<\/span><span class=\"n\">selenium<\/span><span class=\"p\">.<\/span><span class=\"n\">title<\/span><span class=\"p\">)<\/span>\r\n\r\n    <span class=\"k\">def<\/span> <span class=\"nf\">test_index_02<\/span><span class=\"p\">(<\/span><span class=\"bp\">self<\/span><span class=\"p\">):<\/span>\r\n        <span class=\"bp\">self<\/span><span class=\"p\">.<\/span><span class=\"n\">selenium<\/span><span class=\"p\">.<\/span><span class=\"n\">get<\/span><span class=\"p\">(<\/span><span class=\"s\">'%s%s'<\/span> <span class=\"o\">%<\/span> <span class=\"p\">(<\/span><span class=\"bp\">self<\/span><span class=\"p\">.<\/span><span class=\"n\">live_server_url<\/span><span class=\"p\">,<\/span> <span class=\"s\">'\/'<\/span><span class=\"p\">))<\/span>\r\n        <span class=\"n\">message_elem<\/span> <span class=\"o\">=<\/span> <span class=\"bp\">self<\/span><span class=\"p\">.<\/span><span class=\"n\">selenium<\/span><span class=\"p\">.<\/span><span class=\"n\">find_element_by_css_selector<\/span><span class=\"p\">(<\/span><span class=\"s\">'form textarea[name=\"message\"]'<\/span><span class=\"p\">)<\/span>\r\n        <span class=\"n\">message_elem<\/span><span class=\"p\">.<\/span><span class=\"n\">send_keys<\/span><span class=\"p\">(<\/span><span class=\"s\">\"Test Message\"<\/span><span class=\"p\">)<\/span>\r\n        <span class=\"n\">submit_elem<\/span> <span class=\"o\">=<\/span> <span class=\"bp\">self<\/span><span class=\"p\">.<\/span><span class=\"n\">selenium<\/span><span class=\"p\">.<\/span><span class=\"n\">find_element_by_css_selector<\/span><span class=\"p\">(<\/span><span class=\"s\">'form input[type=\"submit\"]'<\/span><span class=\"p\">)<\/span>\r\n        <span class=\"n\">submit_elem<\/span><span class=\"p\">.<\/span><span class=\"n\">click<\/span><span class=\"p\">()<\/span>\r\n        <span class=\"n\">WebDriverWait<\/span><span class=\"p\">(<\/span><span class=\"bp\">self<\/span><span class=\"p\">.<\/span><span class=\"n\">selenium<\/span><span class=\"p\">,<\/span> <span class=\"mi\">15<\/span><span class=\"p\">).<\/span><span class=\"n\">until<\/span><span class=\"p\">(<\/span><span class=\"n\">EC<\/span><span class=\"p\">.<\/span><span class=\"n\">visibility_of_all_elements_located<\/span><span class=\"p\">)<\/span>\r\n\r\n        <span class=\"c1\"># assert Submit Success\r\n<\/span>        <span class=\"c1\"># self.assertEquals('Form Sample', self.selenium.title)\r\n<\/span>\r\n        <span class=\"c1\"># assert Submit 403 Error(CSRF Token Error)\r\n<\/span>        <span class=\"bp\">self<\/span><span class=\"p\">.<\/span><span class=\"n\">assertTrue<\/span><span class=\"p\">(<\/span><span class=\"s\">'403'<\/span> <span class=\"ow\">in<\/span> <span class=\"bp\">self<\/span><span class=\"p\">.<\/span><span class=\"n\">selenium<\/span><span class=\"p\">.<\/span><span class=\"n\">title<\/span><span class=\"p\">)<\/span>\r\n\r\n    <span class=\"o\">@<\/span><span class=\"nb\">classmethod<\/span>\r\n    <span class=\"k\">def<\/span> <span class=\"nf\">tearDownClass<\/span><span class=\"p\">(<\/span><span class=\"n\">cls<\/span><span class=\"p\">):<\/span>\r\n        <span class=\"n\">cls<\/span><span class=\"p\">.<\/span><span class=\"n\">selenium<\/span><span class=\"p\">.<\/span><span class=\"n\">quit<\/span><span class=\"p\">()<\/span>\r\n        <span class=\"nb\">super<\/span><span class=\"p\">().<\/span><span class=\"n\">tearDownClass<\/span><span class=\"p\">()<\/span>\r\n<\/code><\/pre>\n<h2>\u6d4b\u8bd5\u7684\u6267\u884c\u7ed3\u679c<\/h2>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d8c60913a08637a6d0776\/42-0.png\" alt=\"\u30b9\u30af\u30ea\u30fc\u30f3\u30b7\u30e7\u30c3\u30c8 2019-08-20 18.08.56.png\" \/><\/div>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d8c60913a08637a6d0776\/43-0.png\" alt=\"\u30b9\u30af\u30ea\u30fc\u30f3\u30b7\u30e7\u30c3\u30c8 2019-08-20 18.09.33.png\" \/><\/div>\n<h2>\u83b7\u5f97\u7684\u89c1\u89e3 de<\/h2>\n<p>django.test.testcases.TestCase\u3092\u7528\u3044\u305f\u30e6\u30cb\u30c3\u30c8\u30c6\u30b9\u30c8\u3067\u3001CSRF\u30c8\u30fc\u30af\u30f3\u30a8\u30e9\u30fc\u3092\u691c\u77e5\u3059\u308b\u3053\u3068\u306f\u53ef\u80fd<\/p>\n<p>\u305f\u3060\u3057\u3001_pre_setup()\u30e1\u30bd\u30c3\u30c9\u3001setUp()\u30e1\u30bd\u30c3\u30c9\u3092\u30aa\u30fc\u30d0\u30fc\u30e9\u30a4\u30c9\u3057\u3001self.client\u3092CSRF\u30c8\u30fc\u30af\u30f3\u30c1\u30a7\u30c3\u30af\u6709\u52b9\uff08enforce_csrf_checks=True\uff09\u306e\u30af\u30e9\u30a4\u30a2\u30f3\u30c8\u306b\u4e0a\u66f8\u304d\u3059\u308b\u5fc5\u8981\u304c\u3042\u308b<\/p>\n<p>self.client\u81ea\u4f53\u306fdjango.test.testcases.TestCase\u30af\u30e9\u30b9\u306e\u89aa\u30af\u30e9\u30b9\u3067\u3042\u308bdjango.test.testcases.SimpleTestCase\u3067\u5b9a\u7fa9\u3055\u308c\u3066\u3044\u308b<\/p>\n<p>django.test.Client\u306eenforce_csrf_checks\u5f15\u6570\u306f\u30c7\u30d5\u30a9\u30eb\u30c8\u3067False\u3067\u3042\u308b\u305f\u3081\u3001django.test.testcases.SimpleTestCase\u306e_pre_setup()\u30e1\u30bd\u30c3\u30c9\u3067\u751f\u6210\u3055\u308c\u308bself.client\u30aa\u30d6\u30b8\u30a7\u30af\u30c8\u306f\u5e38\u306bCSRF\u30c8\u30fc\u30af\u30f3\u30c1\u30a7\u30c3\u30af\u7121\u52b9\u306b\u306a\u3063\u3066\u3044\u308b<\/p>\n<p>\u3053\u306e\u305f\u3081\u3001\u30c6\u30b9\u30c8\u30af\u30e9\u30b9\u5185\u3067_pre_setup()\u30e1\u30bd\u30c3\u30c9setUp()\u30e1\u30bd\u30c3\u30c9\u3092\u30aa\u30fc\u30d0\u30fc\u30e9\u30a4\u30c9\u3057\u3001self.client\u3092enforce_csrf_checks=True\u3067\u3042\u308b\u30af\u30e9\u30a4\u30a2\u30f3\u30c8\u30aa\u30d6\u30b8\u30a7\u30af\u30c8\u3067\u4e0a\u66f8\u304d\u3059\u308b\u5fc5\u8981\u304c\u751f\u3058\u308b<\/p>\n<p>LiveServerTestCase\u3068Selenium WebDriver\u3092\u7528\u3044\u305f\u30e6\u30cb\u30c3\u30c8\u30c6\u30b9\u30c8\u3067\u3001CSRF\u30c8\u30fc\u30af\u30f3\u30a8\u30e9\u30fc\u3092\u691c\u77e5\u3059\u308b\u3053\u3068\u306f\u53ef\u80fd<\/p>\n<p>Selenium WebDriver\u3067\u306fHTTP\u30b9\u30c6\u30fc\u30bf\u30b9\u30b3\u30fc\u30c9\u3092\u53d6\u5f97\u3059\u308b\u3053\u3068\u306f\u3067\u304d\u306a\u3044\u305f\u3081\u3001\u753b\u9762\u306e\u30bf\u30a4\u30c8\u30eb\u7b49\u3092\u7528\u3044\u3066403\u30a8\u30e9\u30fc\u3092\u691c\u77e5\u3059\u308b\u5fc5\u8981\u304c\u3042\u308b<\/p>\n<h2>\u518d\u5411\u524d\u8fc8\u51fa\u4e00\u6b65<\/h2>\n<p>\u6211\u8ba4\u4e3a\u53ef\u4ee5\u5c06\u5728\u5355\u5143\u6d4b\u8bd5\u4e2d\u68c0\u6d4b\u5230CSRF\u4ee4\u724c\u9519\u8bef\u7684\u6cdb\u5316\u64cd\u4f5c\u5927\u81f4\u5206\u4e3a\u4ee5\u4e0b\u51e0\u4e2a\u65b9\u5411\u3002<\/p>\n<p>django.test.testcases.TestCase\u3092\u62e1\u5f35\u3057\u305f\u30d9\u30fc\u30b9\u30af\u30e9\u30b9\u3092\u4f7f\u7528\u3059\u308b<\/p>\n<p>\u3053\u306e\u30af\u30e9\u30b9\u304b\u3089\u30c6\u30b9\u30c8\u30af\u30e9\u30b9\u3092\u4f5c\u6210\u3059\u308c\u3070\u3001\u7121\u6761\u4ef6\u3067CSRF\u30c8\u30fc\u30af\u30f3\u30a8\u30e9\u30fc\u3092\u691c\u51fa\u3067\u304d\u308b\u3088\u3046\u306b\u3059\u308b<br \/>\n\u30d9\u30fc\u30b9\u306e\u30c6\u30b9\u30c8\u30af\u30e9\u30b9\u3078\u306e\u62e1\u5f35\u6027\u306f\u3042\u308b\u304c\u3001\u30af\u30e9\u30a4\u30a2\u30f3\u30c8\u305d\u306e\u3082\u306e\u3078\u306e\u62e1\u5f35\u6027\u306f\u4f4e\u3044<\/p>\n<p>\u30c6\u30b9\u30c8\u30af\u30e9\u30b9\u3067\u7528\u3044\u308b\u30af\u30e9\u30a4\u30a2\u30f3\u30c8\u3092CSRF\u30c8\u30fc\u30af\u30f3\u30a8\u30e9\u30fc\u691c\u77e5\u6709\u52b9\u306a\u30af\u30e9\u30a4\u30a2\u30f3\u30c8\u306b\u8a2d\u5b9a\u3059\u308b<\/p>\n<p>\u30c6\u30b9\u30c8\u30af\u30e9\u30b9\u306eclient_class\u306b\u3053\u306e\u30af\u30e9\u30a4\u30a2\u30f3\u30c8\u3092\u8a2d\u5b9a\u3059\u308c\u3070CSRF\u30c8\u30fc\u30af\u30f3\u30a8\u30e9\u30fc\u691c\u77e5\u6709\u52b9\u306a\u30af\u30e9\u30a4\u30f3\u30c8\u3092\u4f7f\u7528\u3059\u308b\u3088\u3046\u306b\u3059\u308b<br \/>\nCSRF\u30c8\u30fc\u30af\u30f3\u30a8\u30e9\u30fc\u3092\u691c\u77e5\u3057\u305f\u3044\u30c6\u30b9\u30c8\u30af\u30e9\u30b9\u304c\u8907\u6570\u3042\u308b\u5834\u5408\u306f\u3001\u3059\u3079\u3066\u306e\u30af\u30e9\u30b9\u306eclient_class\u306b\u3053\u306e\u30af\u30e9\u30b9\u3092\u8a2d\u5b9a\u3059\u308b\u5fc5\u8981\u304c\u3042\u308b<\/p>\n<p>\u4e0a\u8a18\uff12\u3064\u306e\u5408\u305b\u6280<\/p>\n<p>\u30af\u30e9\u30a4\u30a2\u30f3\u30c8\u3001\u30d9\u30fc\u30b9\u306e\u30c6\u30b9\u30c8\u30af\u30e9\u30b9\u53cc\u65b9\u306b\u62e1\u5f35\u6027\u3092\u6301\u3064\u3053\u3068\u304c\u3067\u304d\u308b<br \/>\n\u30c6\u30b9\u30c8\u30af\u30e9\u30b9\u5468\u308a\u306e\u30d9\u30fc\u30b9\u90e8\u5206\u304c\u8907\u96d1\u5316\u3059\u308b\u53ef\u80fd\u6027\u304c\u3042\u308b<\/p>\n<h3>\u5728tests\/sample\/test_views_extend_class.py\u4e2d\u4f7f\u7528\u4e86\u6269\u5c55\u4e86django.test.testcases.TestCase\u7684\u57fa\u7c7b\u3002<\/h3>\n<p>CsrfErrorDetactionTestCase:<br \/>\nsetUp()\u30e1\u30bd\u30c3\u30c9\u3067self.client\u3092enforce_csrf_checks=True\u3092\u8a2d\u5b9a\u3057\u305fdjango.test.Client\u306e\u30a4\u30f3\u30b9\u30bf\u30f3\u30b9\u306b\u4e0a\u66f8\u304d\u3059\u308bdjango.test.testcases.TestCase\u306e\u62e1\u5f35\u30af\u30e9\u30b9<\/p>\n<p>SampleViewTest:\u4e0a\u8a18\u306eCsrfErrorDetactionTestCase\u3092\u30d9\u30fc\u30b9\u306b\u4f5c\u6210\u3057\u305f\u30d3\u30e5\u30fc\u306e\u30c6\u30b9\u30c8<\/p>\n<h3>\u5728\u6d4b\u8bd5\u7c7b\u4e2d\uff0c\u5c06\u5ba2\u6237\u7aef\u8bbe\u7f6e\u4e3a\u542f\u7528CSRF\u4ee4\u724c\u9519\u8bef\u68c0\u6d4b\u7684\u5ba2\u6237\u7aef tests\/sample\/test_views_extend_client.py<\/h3>\n<p>CsrfErrorDetectionClient:enforce_csrf_checks\u3092\u30c7\u30d5\u30a9\u30eb\u30c8\u3067True\u306b\u8a2d\u5b9a\u3059\u308bdjango.test.Client<\/p>\n<p>SampleViewTest:\u4e0a\u8a18\u306eCsrfErrorDetectionClient\u3092client_class\u306b\u8a2d\u5b9a\u3057\u305f\u30d3\u30e5\u30fc\u306e\u30c6\u30b9\u30c8<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u603b\u7ed3 \u6709\u65f6\u624b\u52a8\u521b\u5efaDjango\u6a21\u677f\u8868\u5355\u65f6\u4f1a\u72af\u4e00\u4e2a\u9519\u8bef\uff0c\u90a3\u5c31\u662f\u5fd8\u8bb0\u6dfb\u52a0CSRF\u4ee4\u724c\u6807\u7b7e\u3002\u901a\u5e38\u901a\u8fc7\u5728runserv [&hellip;]<\/p>\n","protected":false},"author":6,"featured_media":0,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"tags":[],"class_list":["post-49592","post","type-post","status-publish","format-standard","hentry","category-uncategorized"],"yoast_head":"<!-- This site is optimized with the Yoast SEO Premium plugin v21.5 (Yoast SEO v21.5) - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>\u3010Python\u3011\u3010Django\u3011\u68c0\u6d4bCSRF\u4ee4\u724c\u9519\u8bef\u7684\u6d4b\u8bd5 - Blog - Silicon Cloud<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/www.silicloud.com\/zh\/blog\/\u3010python\u3011\u3010django\u3011\u68c0\u6d4bcsrf\u4ee4\u724c\u9519\u8bef\u7684\u6d4b\u8bd5\/\" \/>\n<meta property=\"og:locale\" content=\"zh_CN\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"\u3010Python\u3011\u3010Django\u3011\u68c0\u6d4bCSRF\u4ee4\u724c\u9519\u8bef\u7684\u6d4b\u8bd5\" \/>\n<meta property=\"og:description\" content=\"\u603b\u7ed3 \u6709\u65f6\u624b\u52a8\u521b\u5efaDjango\u6a21\u677f\u8868\u5355\u65f6\u4f1a\u72af\u4e00\u4e2a\u9519\u8bef\uff0c\u90a3\u5c31\u662f\u5fd8\u8bb0\u6dfb\u52a0CSRF\u4ee4\u724c\u6807\u7b7e\u3002\u901a\u5e38\u901a\u8fc7\u5728runserv [&hellip;]\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.silicloud.com\/zh\/blog\/\u3010python\u3011\u3010django\u3011\u68c0\u6d4bcsrf\u4ee4\u724c\u9519\u8bef\u7684\u6d4b\u8bd5\/\" \/>\n<meta property=\"og:site_name\" content=\"Blog - Silicon Cloud\" \/>\n<meta property=\"article:published_time\" content=\"2023-11-15T07:11:44+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2024-04-30T04:32:04+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d8c60913a08637a6d0776\/42-0.png\" \/>\n<meta name=\"author\" content=\"\u6587, \u7fd4\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"\u4f5c\u8005\" \/>\n\t<meta name=\"twitter:data1\" content=\"\u6587, \u7fd4\" \/>\n\t<meta name=\"twitter:label2\" content=\"\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4\" \/>\n\t<meta name=\"twitter:data2\" content=\"4 \u5206\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"WebPage\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e3%80%90python%e3%80%91%e3%80%90django%e3%80%91%e6%a3%80%e6%b5%8bcsrf%e4%bb%a4%e7%89%8c%e9%94%99%e8%af%af%e7%9a%84%e6%b5%8b%e8%af%95\/\",\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e3%80%90python%e3%80%91%e3%80%90django%e3%80%91%e6%a3%80%e6%b5%8bcsrf%e4%bb%a4%e7%89%8c%e9%94%99%e8%af%af%e7%9a%84%e6%b5%8b%e8%af%95\/\",\"name\":\"\u3010Python\u3011\u3010Django\u3011\u68c0\u6d4bCSRF\u4ee4\u724c\u9519\u8bef\u7684\u6d4b\u8bd5 - Blog - Silicon Cloud\",\"isPartOf\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#website\"},\"datePublished\":\"2023-11-15T07:11:44+00:00\",\"dateModified\":\"2024-04-30T04:32:04+00:00\",\"author\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/64d5cc7727fffbff2f9a2a8da1de3e5c\"},\"breadcrumb\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e3%80%90python%e3%80%91%e3%80%90django%e3%80%91%e6%a3%80%e6%b5%8bcsrf%e4%bb%a4%e7%89%8c%e9%94%99%e8%af%af%e7%9a%84%e6%b5%8b%e8%af%95\/#breadcrumb\"},\"inLanguage\":\"zh-Hans\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/www.silicloud.com\/zh\/blog\/%e3%80%90python%e3%80%91%e3%80%90django%e3%80%91%e6%a3%80%e6%b5%8bcsrf%e4%bb%a4%e7%89%8c%e9%94%99%e8%af%af%e7%9a%84%e6%b5%8b%e8%af%95\/\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e3%80%90python%e3%80%91%e3%80%90django%e3%80%91%e6%a3%80%e6%b5%8bcsrf%e4%bb%a4%e7%89%8c%e9%94%99%e8%af%af%e7%9a%84%e6%b5%8b%e8%af%95\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"\u9996\u9875\",\"item\":\"https:\/\/www.silicloud.com\/zh\/blog\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"\u3010Python\u3011\u3010Django\u3011\u68c0\u6d4bCSRF\u4ee4\u724c\u9519\u8bef\u7684\u6d4b\u8bd5\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#website\",\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/\",\"name\":\"Blog - Silicon Cloud\",\"description\":\"\",\"inLanguage\":\"zh-Hans\"},{\"@type\":\"Person\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/64d5cc7727fffbff2f9a2a8da1de3e5c\",\"name\":\"\u6587, \u7fd4\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/920c3d673e0bccacc98e5e6b7149bb3c22edd8d39cb753e5d7d7e471498118a1?s=96&d=mm&r=g\",\"contentUrl\":\"https:\/\/secure.gravatar.com\/avatar\/920c3d673e0bccacc98e5e6b7149bb3c22edd8d39cb753e5d7d7e471498118a1?s=96&d=mm&r=g\",\"caption\":\"\u6587, \u7fd4\"},\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/author\/wenxiang\/\"},{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e3%80%90python%e3%80%91%e3%80%90django%e3%80%91%e6%a3%80%e6%b5%8bcsrf%e4%bb%a4%e7%89%8c%e9%94%99%e8%af%af%e7%9a%84%e6%b5%8b%e8%af%95\/#local-main-organization-logo\",\"url\":\"\",\"contentUrl\":\"\",\"caption\":\"Blog - Silicon Cloud\"}]}<\/script>\n<!-- \/ Yoast SEO Premium plugin. -->","yoast_head_json":{"title":"\u3010Python\u3011\u3010Django\u3011\u68c0\u6d4bCSRF\u4ee4\u724c\u9519\u8bef\u7684\u6d4b\u8bd5 - Blog - Silicon Cloud","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/www.silicloud.com\/zh\/blog\/\u3010python\u3011\u3010django\u3011\u68c0\u6d4bcsrf\u4ee4\u724c\u9519\u8bef\u7684\u6d4b\u8bd5\/","og_locale":"zh_CN","og_type":"article","og_title":"\u3010Python\u3011\u3010Django\u3011\u68c0\u6d4bCSRF\u4ee4\u724c\u9519\u8bef\u7684\u6d4b\u8bd5","og_description":"\u603b\u7ed3 \u6709\u65f6\u624b\u52a8\u521b\u5efaDjango\u6a21\u677f\u8868\u5355\u65f6\u4f1a\u72af\u4e00\u4e2a\u9519\u8bef\uff0c\u90a3\u5c31\u662f\u5fd8\u8bb0\u6dfb\u52a0CSRF\u4ee4\u724c\u6807\u7b7e\u3002\u901a\u5e38\u901a\u8fc7\u5728runserv [&hellip;]","og_url":"https:\/\/www.silicloud.com\/zh\/blog\/\u3010python\u3011\u3010django\u3011\u68c0\u6d4bcsrf\u4ee4\u724c\u9519\u8bef\u7684\u6d4b\u8bd5\/","og_site_name":"Blog - Silicon Cloud","article_published_time":"2023-11-15T07:11:44+00:00","article_modified_time":"2024-04-30T04:32:04+00:00","og_image":[{"url":"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d8c60913a08637a6d0776\/42-0.png"}],"author":"\u6587, \u7fd4","twitter_card":"summary_large_image","twitter_misc":{"\u4f5c\u8005":"\u6587, \u7fd4","\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4":"4 \u5206"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"WebPage","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e3%80%90python%e3%80%91%e3%80%90django%e3%80%91%e6%a3%80%e6%b5%8bcsrf%e4%bb%a4%e7%89%8c%e9%94%99%e8%af%af%e7%9a%84%e6%b5%8b%e8%af%95\/","url":"https:\/\/www.silicloud.com\/zh\/blog\/%e3%80%90python%e3%80%91%e3%80%90django%e3%80%91%e6%a3%80%e6%b5%8bcsrf%e4%bb%a4%e7%89%8c%e9%94%99%e8%af%af%e7%9a%84%e6%b5%8b%e8%af%95\/","name":"\u3010Python\u3011\u3010Django\u3011\u68c0\u6d4bCSRF\u4ee4\u724c\u9519\u8bef\u7684\u6d4b\u8bd5 - Blog - Silicon Cloud","isPartOf":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/#website"},"datePublished":"2023-11-15T07:11:44+00:00","dateModified":"2024-04-30T04:32:04+00:00","author":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/64d5cc7727fffbff2f9a2a8da1de3e5c"},"breadcrumb":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e3%80%90python%e3%80%91%e3%80%90django%e3%80%91%e6%a3%80%e6%b5%8bcsrf%e4%bb%a4%e7%89%8c%e9%94%99%e8%af%af%e7%9a%84%e6%b5%8b%e8%af%95\/#breadcrumb"},"inLanguage":"zh-Hans","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.silicloud.com\/zh\/blog\/%e3%80%90python%e3%80%91%e3%80%90django%e3%80%91%e6%a3%80%e6%b5%8bcsrf%e4%bb%a4%e7%89%8c%e9%94%99%e8%af%af%e7%9a%84%e6%b5%8b%e8%af%95\/"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e3%80%90python%e3%80%91%e3%80%90django%e3%80%91%e6%a3%80%e6%b5%8bcsrf%e4%bb%a4%e7%89%8c%e9%94%99%e8%af%af%e7%9a%84%e6%b5%8b%e8%af%95\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"\u9996\u9875","item":"https:\/\/www.silicloud.com\/zh\/blog\/"},{"@type":"ListItem","position":2,"name":"\u3010Python\u3011\u3010Django\u3011\u68c0\u6d4bCSRF\u4ee4\u724c\u9519\u8bef\u7684\u6d4b\u8bd5"}]},{"@type":"WebSite","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#website","url":"https:\/\/www.silicloud.com\/zh\/blog\/","name":"Blog - Silicon Cloud","description":"","inLanguage":"zh-Hans"},{"@type":"Person","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/64d5cc7727fffbff2f9a2a8da1de3e5c","name":"\u6587, \u7fd4","image":{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/image\/","url":"https:\/\/secure.gravatar.com\/avatar\/920c3d673e0bccacc98e5e6b7149bb3c22edd8d39cb753e5d7d7e471498118a1?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/920c3d673e0bccacc98e5e6b7149bb3c22edd8d39cb753e5d7d7e471498118a1?s=96&d=mm&r=g","caption":"\u6587, \u7fd4"},"url":"https:\/\/www.silicloud.com\/zh\/blog\/author\/wenxiang\/"},{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e3%80%90python%e3%80%91%e3%80%90django%e3%80%91%e6%a3%80%e6%b5%8bcsrf%e4%bb%a4%e7%89%8c%e9%94%99%e8%af%af%e7%9a%84%e6%b5%8b%e8%af%95\/#local-main-organization-logo","url":"","contentUrl":"","caption":"Blog - Silicon Cloud"}]}},"_links":{"self":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/49592","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/users\/6"}],"replies":[{"embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/comments?post=49592"}],"version-history":[{"count":2,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/49592\/revisions"}],"predecessor-version":[{"id":91929,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/49592\/revisions\/91929"}],"wp:attachment":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/media?parent=49592"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/categories?post=49592"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/tags?post=49592"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}