{"id":23831,"date":"2024-11-21T11:14:31","date_gmt":"2024-11-21T03:14:31","guid":{"rendered":"https:\/\/fwq.ai\/blog\/23831\/"},"modified":"2024-11-21T11:14:31","modified_gmt":"2024-11-21T03:14:31","slug":"%e4%bd%bf%e7%94%a8yii%e6%a1%86%e6%9e%b6%e5%88%9b%e5%bb%ba%e5%a9%9a%e7%a4%bc%e7%ad%96%e5%88%92%e7%bd%91%e7%ab%99","status":"publish","type":"post","link":"https:\/\/fwq.ai\/blog\/23831\/","title":{"rendered":"\u4f7f\u7528Yii\u6846\u67b6\u521b\u5efa\u5a5a\u793c\u7b56\u5212\u7f51\u7ad9"},"content":{"rendered":"<p>\u5a5a\u793c\u662f\u6bcf\u4e2a\u4eba\u751f\u547d\u4e2d\u7684\u91cd\u8981\u65f6\u523b\uff0c\u5bf9\u4e8e\u591a\u6570\u4eba\u800c\u8a00\uff0c\u4e00\u573a\u7f8e\u4e3d\u7684\u5a5a\u793c\u662f\u5341\u5206\u91cd\u8981\u7684\u3002\u5728\u7b56\u5212\u5a5a\u793c\u65f6\uff0c\u592b\u59bb\u53cc\u65b9\u6ce8\u91cd\u7684\u4e0d\u4ec5\u4ec5\u662f\u5a5a\u793c\u7684\u89c4\u6a21\u548c\u534e\u4e3d\u7a0b\u5ea6\uff0c\u800c\u66f4\u52a0\u6ce8\u91cd\u5a5a\u793c\u7684\u7ec6\u8282\u548c\u4e2a\u6027\u5316\u4f53\u9a8c\u3002\u4e3a\u4e86\u89e3\u51b3\u8fd9\u4e00\u95ee\u9898\uff0c\u8bb8\u591a\u5a5a\u793c\u7b56\u5212\u516c\u53f8\u6210\u7acb\u5e76\u5f00\u53d1\u4e86\u81ea\u5df1\u7684\u7f51\u7ad9\u3002\u672c\u6587\u5c06\u4ecb\u7ecd\u5982\u4f55\u4f7f\u7528yii\u6846\u67b6\u521b\u5efa\u4e00\u4e2a\u5a5a\u793c\u7b56\u5212\u7f51\u7ad9\u3002<\/p>\n<p>Yii\u6846\u67b6\u662f\u4e00\u4e2a\u9ad8\u6027\u80fd\u7684PHP\u6846\u67b6\uff0c\u5176\u7b80\u5355\u6613\u7528\u7684\u7279\u70b9\u6df1\u53d7\u5e7f\u5927\u5f00\u53d1\u8005\u7684\u559c\u7231\u3002\u4f7f\u7528Yii\u6846\u67b6\uff0c\u6211\u4eec\u80fd\u591f\u66f4\u52a0\u9ad8\u6548\u5730\u5f00\u53d1\u51fa\u4e00\u4e2a\u9ad8\u8d28\u91cf\u7684\u7f51\u7ad9\u3002\u4e0b\u9762\u5c06\u4ecb\u7ecd\u5982\u4f55\u4f7f\u7528Yii\u6846\u67b6\u521b\u5efa\u4e00\u4e2a\u5a5a\u793c\u7b56\u5212\u7f51\u7ad9\u3002<\/p>\n<p>\u7b2c\u4e00\u6b65\uff1a\u5b89\u88c5Yii\u6846\u67b6<br \/>\u9996\u5148\uff0c\u6211\u4eec\u9700\u8981\u5b89\u88c5Yii\u6846\u67b6\u3002\u53ef\u4ee5\u901a\u8fc7composer\u8fdb\u884c\u5b89\u88c5\uff1a<\/p>\n<pre>composer create-project --prefer-dist yiisoft\/yii2-app-basic basic<\/pre>\n<p>  \u767b\u5f55\u540e\u590d\u5236   <\/p>\n<p>\u6216\u8005\u4e0b\u8f7dYii\u6846\u67b6\u538b\u7f29\u5305\uff0c\u89e3\u538b\u81f3\u670d\u52a1\u5668\u76ee\u5f55\u4e0b\u3002\u89e3\u538b\u540e\uff0c\u8fd0\u884c\u4ee5\u4e0b\u547d\u4ee4\u5b89\u88c5\u6240\u9700\u4f9d\u8d56\uff1a<\/p>\n<pre>php composer.phar install<\/pre>\n<p>  \u767b\u5f55\u540e\u590d\u5236   <\/p>\n<p>\u7b2c\u4e8c\u6b65\uff1a\u521b\u5efa\u6570\u636e\u5e93\u53ca\u76f8\u5e94\u8868<br \/>\u5728\u4e0a\u4e00\u6b65\u4e2d\uff0c\u6211\u4eec\u5df2\u7ecf\u6210\u529f\u5b89\u88c5\u4e86Yii\u6846\u67b6\u3002\u63a5\u4e0b\u6765\uff0c\u9700\u8981\u521b\u5efa\u6570\u636e\u5e93\u53ca\u76f8\u5e94\u8868\u3002\u53ef\u4ee5\u901a\u8fc7MySQL Workbench\u7b49\u5de5\u5177\u76f4\u63a5\u521b\u5efa\u3002<\/p>\n<p>\u521b\u5efa\u4e00\u4e2a\u540d\u4e3awedding\u7684\u6570\u636e\u5e93\uff0c\u7136\u540e\u521b\u5efa\u5982\u4e0b\u7ed3\u6784\u7684\u8868\uff1a<\/p>\n<pre>CREATE TABLE IF NOT EXISTS `user` (\n    `id` INT UNSIGNED AUTO_INCREMENT PRIMARY KEY,\n    `username` VARCHAR(255) NOT NULL,\n    `password_hash` VARCHAR(255) NOT NULL,\n    `email` VARCHAR(255) NOT NULL,\n    `auth_key` VARCHAR(255) NOT NULL,\n    `status` SMALLINT NOT NULL DEFAULT 10,\n    `created_at` INT NOT NULL,\n    `updated_at` INT NOT NULL\n) ENGINE=InnoDB DEFAULT CHARSET=utf8;\n\nCREATE TABLE IF NOT EXISTS `article` (\n    `id` INT UNSIGNED AUTO_INCREMENT PRIMARY KEY,\n    `title` VARCHAR(255) NOT NULL,\n    `content` TEXT NOT NULL,\n    `status` SMALLINT NOT NULL DEFAULT 10,\n    `created_at` INT NOT NULL,\n    `updated_at` INT NOT NULL,\n    `user_id` INT UNSIGNED NOT NULL,\n    CONSTRAINT `fk_article_user_id` FOREIGN KEY (`user_id`) REFERENCES `user` (`id`) ON DELETE CASCADE ON UPDATE CASCADE\n) ENGINE=InnoDB DEFAULT CHARSET=utf8;<\/pre>\n<p>  \u767b\u5f55\u540e\u590d\u5236   <\/p>\n<p>\u5176\u4e2d\uff0cuser\u8868\u5b58\u50a8\u7528\u6237\u4fe1\u606f\uff0carticle\u8868\u5b58\u50a8\u6587\u7ae0\u4fe1\u606f\u3002<\/p>\n<p>\u7b2c\u4e09\u6b65\uff1a\u521b\u5efa\u6a21\u578b<br \/>\u5728Yii\u6846\u67b6\u4e2d\uff0c\u6a21\u578b\u662fMVC\u67b6\u6784\u4e2dM\uff08Model\uff09\u7684\u4e00\u90e8\u5206\uff0c\u8d1f\u8d23\u5904\u7406\u6570\u636e\u3002\u6211\u4eec\u9700\u8981\u521b\u5efaUser\u548cArticle\u4e24\u4e2a\u6a21\u578b\uff1a<\/p>\n<pre>class User extends ActiveRecord implements IdentityInterface\n{\n    public static function findIdentity($id)\n    {\n        return static::findOne($id);\n    }\n\n    public static function findIdentityByAccessToken($token, $type = null)\n    {\n        throw new NotSupportedException('\"findIdentityByAccessToken\" is not implemented.');\n    }\n\n    public function getId()\n    {\n        return $this-&amp;gt;getPrimaryKey();\n    }\n\n    public function getAuthKey()\n    {\n        return $this-&amp;gt;auth_key;\n    }\n\n    public function validateAuthKey($authKey)\n    {\n        return $this-&amp;gt;getAuthKey() === $authKey;\n    }\n\n    public static function findByUsername($username)\n    {\n        return static::findOne(['username' =&amp;gt; $username, 'status' =&amp;gt; self::STATUS_ACTIVE]);\n    }\n\n    public function validatePassword($password)\n    {\n        return Yii::$app-&amp;gt;security-&amp;gt;validatePassword($password, $this-&amp;gt;password_hash);\n    }\n}\n\nclass Article extends ActiveRecord\n{\n    public function getUser()\n    {\n        return $this-&amp;gt;hasOne(User::className(), ['id' =&amp;gt; 'user_id']);\n    }\n}<\/pre>\n<p>  \u767b\u5f55\u540e\u590d\u5236   <\/p>\n<p>\u5728\u4e0a\u9762\u7684\u4ee3\u7801\u4e2d\uff0c\u6211\u4eec\u901a\u8fc7\u7ee7\u627fActiveRecord\u7c7b\u5b9a\u4e49\u4e86User\u548cArticle\u4e24\u4e2a\u6a21\u578b\u3002User\u6a21\u578b\u5b9e\u73b0\u4e86IdentityInterface\u63a5\u53e3\uff0c\u7528\u4e8e\u8eab\u4efd\u9a8c\u8bc1\uff1bArticle\u6a21\u578b\u4e2d\u901a\u8fc7getUser()\u65b9\u6cd5\u5b9a\u4e49\u4e86\u7528\u6237\u548c\u6587\u7ae0\u4e4b\u95f4\u7684\u5173\u7cfb\u3002<\/p>\n<p>\u7b2c\u56db\u6b65\uff1a\u521b\u5efa\u63a7\u5236\u5668\u548c\u89c6\u56fe<br \/>\u5728Yii\u6846\u67b6\u4e2d\uff0c\u63a7\u5236\u5668\u662fMVC\u67b6\u6784\u4e2dC\uff08Controller\uff09\u7684\u4e00\u90e8\u5206\uff0c\u8d1f\u8d23\u5904\u7406\u63a5\u6536\u5230\u7684web\u8bf7\u6c42\u3002\u6211\u4eec\u9700\u8981\u521b\u5efa\u4e24\u4e2a\u63a7\u5236\u5668\uff1aUserController\u548cArticleController\uff0c\u4ee5\u53ca\u76f8\u5e94\u7684\u89c6\u56fe\u3002<\/p>\n<p>UserController\u7528\u4e8e\u5904\u7406\u7528\u6237\u6ce8\u518c\u3001\u767b\u5f55\u7b49\u64cd\u4f5c\uff1a<\/p>\n<pre>class UserController extends Controller\n{\n    public function actionSignup()\n    {\n        $model = new SignupForm();\n\n        if ($model-&amp;gt;load(Yii::$app-&amp;gt;request-&amp;gt;post()) &amp;amp;&amp;amp; $model-&amp;gt;signup()) {\n            Yii::$app-&amp;gt;session-&amp;gt;setFlash('success', 'Thank you for registration. Please check your inbox for verification email.');\n            return $this-&amp;gt;goHome();\n        }\n\n        return $this-&amp;gt;render('signup', [\n            'model' =&amp;gt; $model,\n        ]);\n    }\n\n    public function actionLogin()\n    {\n        $model = new LoginForm();\n\n        if ($model-&amp;gt;load(Yii::$app-&amp;gt;request-&amp;gt;post()) &amp;amp;&amp;amp; $model-&amp;gt;login()) {\n            return $this-&amp;gt;goBack();\n        }\n\n        return $this-&amp;gt;render('login', [\n            'model' =&amp;gt; $model,\n        ]);\n    }\n\n    public function actionLogout()\n    {\n        Yii::$app-&amp;gt;user-&amp;gt;logout();\n\n        return $this-&amp;gt;goHome();\n    }\n}<\/pre>\n<p>  \u767b\u5f55\u540e\u590d\u5236   <\/p>\n<p>ArticleController\u7528\u4e8e\u5904\u7406\u6587\u7ae0\u7f16\u8f91\u3001\u663e\u793a\u7b49\u64cd\u4f5c\uff1a<\/p>\n<pre>class ArticleController extends Controller\n{\n    public function behaviors()\n    {\n        return [\n            'access' =&amp;gt; [\n                'class' =&amp;gt; AccessControl::className(),\n                'only' =&amp;gt; ['create', 'update'],\n                'rules' =&amp;gt; [\n                    [\n                        'actions' =&amp;gt; ['create', 'update'],\n                        'allow' =&amp;gt; true,\n                        'roles' =&amp;gt; ['@'],\n                    ],\n                ],\n            ],\n            'verbs' =&amp;gt; [\n                'class' =&amp;gt; VerbFilter::className(),\n                'actions' =&amp;gt; [\n                    'delete' =&amp;gt; ['POST'],\n                ],\n            ],\n        ];\n    }\n\n    public function actionIndex()\n    {\n        $dataProvider = new ActiveDataProvider([\n            'query' =&amp;gt; Article::find(),\n        ]);\n\n        return $this-&amp;gt;render('index', [\n            'dataProvider' =&amp;gt; $dataProvider,\n        ]);\n    }\n\n    public function actionView($id)\n    {\n        return $this-&amp;gt;render('view', [\n            'model' =&amp;gt; $this-&amp;gt;findModel($id),\n        ]);\n    }\n\n    public function actionCreate()\n    {\n        $model = new Article();\n\n        if ($model-&amp;gt;load(Yii::$app-&amp;gt;request-&amp;gt;post()) &amp;amp;&amp;amp; $model-&amp;gt;save()) {\n            return $this-&amp;gt;redirect(['view', 'id' =&amp;gt; $model-&amp;gt;id]);\n        }\n\n        return $this-&amp;gt;render('create', [\n            'model' =&amp;gt; $model,\n        ]);\n    }\n\n    public function actionUpdate($id)\n    {\n        $model = $this-&amp;gt;findModel($id);\n\n        if ($model-&amp;gt;load(Yii::$app-&amp;gt;request-&amp;gt;post()) &amp;amp;&amp;amp; $model-&amp;gt;save()) {\n            return $this-&amp;gt;redirect(['view', 'id' =&amp;gt; $model-&amp;gt;id]);\n        }\n\n        return $this-&amp;gt;render('update', [\n            'model' =&amp;gt; $model,\n        ]);\n    }\n\n    public function actionDelete($id)\n    {\n        $this-&amp;gt;findModel($id)-&amp;gt;delete();\n\n        return $this-&amp;gt;redirect(['index']);\n    }\n\n    protected function findModel($id)\n    {\n        if (($model = Article::findOne($id)) !== null) {\n            return $model;\n        }\n\n        throw new NotFoundHttpException('The requested page does not exist.');\n    }\n}<\/pre>\n<p>  \u767b\u5f55\u540e\u590d\u5236   <\/p>\n<p>\u5728\u4ee5\u4e0a\u4ee3\u7801\u4e2d\uff0c\u6211\u4eec\u4f7f\u7528\u4e86Yii\u5185\u7f6e\u7684\u4e00\u4e9b\u7ec4\u4ef6\u548c\u64cd\u4f5c\uff0c\u4f8b\u5982AccessControl\u3001ActiveDataProvider\u3001VerbFilter\u7b49\uff0c\u4ee5\u66f4\u52a0\u9ad8\u6548\u5730\u8fdb\u884c\u5f00\u53d1\u3002<\/p>\n<p>\u7b2c\u4e94\u6b65\uff1a\u914d\u7f6e\u8def\u7531\u548c\u6570\u636e\u5e93<br \/>\u5728Yii\u6846\u67b6\u4e2d\uff0c\u9700\u8981\u5728\u914d\u7f6e\u6587\u4ef6\u4e2d\u8fdb\u884c\u8def\u7531\u914d\u7f6e\u548c\u6570\u636e\u5e93\u8fde\u63a5\u914d\u7f6e\u3002\u6211\u4eec\u9700\u8981\u7f16\u8f91\u5982\u4e0b\u4e24\u4e2a\u6587\u4ef6\uff1a<\/p>\n<p>\/config\/web.php\uff1a<\/p>\n<pre>return [\n    'id' =&amp;gt; 'basic',\n    'basePath' =&amp;gt; dirname(__DIR__),\n    'bootstrap' =&amp;gt; ['log'],\n    'components' =&amp;gt; [\n        'request' =&amp;gt; [\n            'csrfParam' =&amp;gt; '_csrf',\n        ],\n        'user' =&amp;gt; [\n            'identityClass' =&amp;gt; 'appmodelsUser',\n            'enableAutoLogin' =&amp;gt; true,\n        ],\n        'session' =&amp;gt; [\n            \/\/ this is the name of the session cookie used for login on the frontend\n            'name' =&amp;gt; 'wedding_session',\n        ],\n        'log' =&amp;gt; [\n            'traceLevel' =&amp;gt; YII_DEBUG ? 3 : 0,\n            'targets' =&amp;gt; [\n                [\n                    'class' =&amp;gt; 'yiilogFileTarget',\n                    'levels' =&amp;gt; ['error', 'warning'],\n                ],\n            ],\n        ],\n        'urlManager' =&amp;gt; [\n            'enablePrettyUrl' =&amp;gt; true,\n            'showScriptName' =&amp;gt; false,\n            'rules' =&amp;gt; [\n                '' =&amp;gt; 'article\/index',\n                '&lt;controller&gt;\/&lt;action&gt;' =&amp;gt; '&lt;controller&gt;\/&lt;action&gt;',\n                '&lt;controller&gt;\/&lt;action&gt;\/&lt;d&gt;' =&amp;gt; '&lt;controller&gt;\/&lt;action&gt;',\n            ],\n        ],\n        'db' =&amp;gt; require __DIR__ . '\/db.php',\n    ],\n    'params' =&amp;gt; $params,\n];&lt;\/action&gt;&lt;\/controller&gt;&lt;\/d&gt;&lt;\/action&gt;&lt;\/controller&gt;&lt;\/action&gt;&lt;\/controller&gt;&lt;\/action&gt;&lt;\/controller&gt;<\/pre>\n<p>  \u767b\u5f55\u540e\u590d\u5236   <\/p>\n<p>\u4e0a\u9762\u7684\u4ee3\u7801\u4e2d\uff0c\u9700\u8981\u914d\u7f6e\u6570\u636e\u5e93\u3001URL\u8def\u7531\u7b49\u4fe1\u606f\uff0c\u4ee5\u4fbf\u9879\u76ee\u80fd\u591f\u987a\u5229\u8fd0\u884c\u3002\/config\/db.php\u6587\u4ef6\u4e2d\u5219\u9700\u8981\u914d\u7f6e\u6570\u636e\u5e93\u8fde\u63a5\u4fe1\u606f\uff0c\u4ee5\u4fbfYii\u6846\u67b6\u4e0e\u6570\u636e\u5e93\u8fdb\u884c\u4ea4\u4e92\u3002<\/p>\n<p>\u6700\u540e\uff0c\u6211\u4eec\u8fd8\u9700\u8981\u5728\/config\/params.php\u4e2d\u914d\u7f6e\u90ae\u4ef6\u53d1\u9001\u4fe1\u606f\uff0c\u4ee5\u4fbf\u7528\u6237\u6ce8\u518c\u6210\u529f\u540e\u80fd\u591f\u6536\u5230\u9a8c\u8bc1\u90ae\u4ef6\u3002<\/p>\n<p>\u5230\u6b64\uff0c\u6211\u4eec\u5df2\u7ecf\u5b8c\u6210\u4e86\u4f7f\u7528Yii\u6846\u67b6\u521b\u5efa\u5a5a\u793c\u7b56\u5212\u7f51\u7ad9\u7684\u5168\u90e8\u8fc7\u7a0b\u3002\u901a\u8fc7\u672c\u6587\u7684\u4ecb\u7ecd\uff0c\u60a8\u5df2\u7ecf\u4e86\u89e3\u4e86Yii\u6846\u67b6\u7684\u57fa\u672c\u4f7f\u7528\u65b9\u6cd5\uff0c\u4ee5\u53ca\u5982\u4f55\u521b\u5efa\u4e00\u4e2a\u7b80\u5355\u7684\u5a5a\u793c\u7b56\u5212\u7f51\u7ad9\u3002\u5982\u679c\u60a8\u60f3\u8981\u521b\u5efa\u66f4\u52a0\u590d\u6742\u3001\u66f4\u52a0\u4e13\u4e1a\u7684\u5a5a\u793c\u7f51\u7ad9\uff0c\u8fd8\u9700\u8981\u8fdb\u4e00\u6b65\u6df1\u5165\u5b66\u4e60Yii\u6846\u67b6\uff0c\u4ee5\u66f4\u52a0\u9ad8\u6548\u5730\u5f00\u53d1web\u5e94\u7528\u7a0b\u5e8f\u3002<\/p>\n<p>\u4ee5\u4e0a\u5c31\u662f\u4f7f\u7528Yii\u6846\u67b6\u521b\u5efa\u5a5a\u793c\u7b56\u5212\u7f51\u7ad9\u7684\u8be6\u7ec6\u5185\u5bb9\uff0c\u66f4\u591a\u8bf7\u5173\u6ce8\u7c73\u4e91\u5176\u5b83\u76f8\u5173\u6587\u7ae0\uff01<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u5a5a\u793c\u662f\u6bcf\u4e2a\u4eba\u751f\u547d\u4e2d\u7684\u91cd\u8981\u65f6\u523b\uff0c\u5bf9\u4e8e\u591a\u6570\u4eba\u800c\u8a00\uff0c\u4e00\u573a\u7f8e\u4e3d\u7684\u5a5a\u793c\u662f\u5341\u5206\u91cd\u8981\u7684\u3002\u5728\u7b56\u5212\u5a5a\u793c\u65f6\uff0c\u592b\u59bb\u53cc\u65b9\u6ce8\u91cd\u7684\u4e0d\u4ec5\u4ec5\u662f\u5a5a\u793c\u7684\u89c4\u6a21\u548c\u534e\u4e3d\u7a0b\u5ea6\uff0c\u800c\u66f4\u52a0\u6ce8\u91cd\u5a5a\u793c\u7684\u7ec6\u8282\u548c\u4e2a\u6027\u5316\u4f53\u9a8c\u3002\u4e3a\u4e86\u89e3\u51b3\u8fd9\u4e00\u95ee\u9898\uff0c\u8bb8\u591a\u5a5a\u793c\u7b56\u5212\u516c\u53f8\u6210\u7acb\u5e76\u5f00\u53d1\u4e86\u81ea\u5df1\u7684\u7f51\u7ad9\u3002\u672c\u6587\u5c06\u4ecb\u7ecd\u5982\u4f55\u4f7f\u7528yii\u6846\u67b6\u521b\u5efa\u4e00\u4e2a\u5a5a\u793c\u7b56\u5212\u7f51\u7ad9\u3002 Yii\u6846\u67b6\u662f\u4e00\u4e2a\u9ad8\u6027\u80fd\u7684PHP\u6846\u67b6\uff0c\u5176\u7b80\u5355\u6613\u7528\u7684\u7279\u70b9\u6df1\u53d7\u5e7f\u5927\u5f00\u53d1\u8005\u7684\u559c\u7231\u3002\u4f7f\u7528Yii\u6846\u67b6\uff0c\u6211\u4eec\u80fd\u591f\u66f4\u52a0\u9ad8\u6548\u5730\u5f00\u53d1\u51fa\u4e00\u4e2a\u9ad8\u8d28\u91cf\u7684\u7f51\u7ad9\u3002\u4e0b\u9762\u5c06\u4ecb\u7ecd\u5982\u4f55\u4f7f\u7528Yii\u6846\u67b6\u521b\u5efa\u4e00\u4e2a\u5a5a\u793c\u7b56\u5212\u7f51\u7ad9\u3002 \u7b2c\u4e00\u6b65\uff1a\u5b89\u88c5Yii\u6846\u67b6\u9996\u5148\uff0c\u6211\u4eec\u9700\u8981\u5b89\u88c5Yii\u6846\u67b6\u3002\u53ef\u4ee5\u901a\u8fc7composer\u8fdb\u884c\u5b89\u88c5\uff1a composer create-project &#8211;prefer-dist yiisoft\/yii2-app-basic basic \u767b\u5f55\u540e\u590d\u5236 \u6216\u8005\u4e0b\u8f7dYii\u6846\u67b6\u538b\u7f29\u5305\uff0c\u89e3\u538b\u81f3\u670d\u52a1\u5668\u76ee\u5f55\u4e0b\u3002\u89e3\u538b\u540e\uff0c\u8fd0\u884c\u4ee5\u4e0b\u547d\u4ee4\u5b89\u88c5\u6240\u9700\u4f9d\u8d56\uff1a php composer.phar install \u767b\u5f55\u540e\u590d\u5236 \u7b2c\u4e8c\u6b65\uff1a\u521b\u5efa\u6570\u636e\u5e93\u53ca\u76f8\u5e94\u8868\u5728\u4e0a\u4e00\u6b65\u4e2d\uff0c\u6211\u4eec\u5df2\u7ecf\u6210\u529f\u5b89\u88c5\u4e86Yii\u6846\u67b6\u3002\u63a5\u4e0b\u6765\uff0c\u9700\u8981\u521b\u5efa\u6570\u636e\u5e93\u53ca\u76f8\u5e94\u8868\u3002\u53ef\u4ee5\u901a\u8fc7MySQL Workbench\u7b49\u5de5\u5177\u76f4\u63a5\u521b\u5efa\u3002 \u521b\u5efa\u4e00\u4e2a\u540d\u4e3awedding\u7684\u6570\u636e\u5e93\uff0c\u7136\u540e\u521b\u5efa\u5982\u4e0b\u7ed3\u6784\u7684\u8868\uff1a CREATE TABLE IF NOT EXISTS `user` ( `id` INT UNSIGNED AUTO_INCREMENT PRIMARY KEY, `username` VARCHAR(255) NOT NULL, `password_hash` VARCHAR(255) NOT NULL, `email` VARCHAR(255) NOT NULL, `auth_key` VARCHAR(255) NOT NULL, `status` SMALLINT NOT NULL DEFAULT 10, `created_at` INT NOT [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"closed","ping_status":"","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[16],"tags":[],"class_list":["post-23831","post","type-post","status-publish","format-standard","hentry","category-16"],"_links":{"self":[{"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/posts\/23831","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/comments?post=23831"}],"version-history":[{"count":0,"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/posts\/23831\/revisions"}],"wp:attachment":[{"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/media?parent=23831"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/categories?post=23831"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/fwq.ai\/blog\/wp-json\/wp\/v2\/tags?post=23831"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}