Heim  >  Artikel  >  PHP-Framework  >  thinkphp5.1 realisiert die Front-End- und Back-End-Trennung sowie die Interaktion mit PHP und vue.js

thinkphp5.1 realisiert die Front-End- und Back-End-Trennung sowie die Interaktion mit PHP und vue.js

藏色散人
藏色散人nach vorne
2020-11-18 15:44:594943Durchsuche

Die folgende thinkphpFramework-Tutorial-Kolumne stellt Ihnen vor, wie thinkphp5.1 und php und vue.js die Front-End- und Back-End-Trennung und -Interaktion erreichen. Ich hoffe, dass es für Freunde in Not hilfreich sein wird!

Das Hauptziel besteht darin, vue.js zu verwenden, um das vom Front-End erhaltene Konto und Passwort an das Backend zu übertragen, und dann das tp5.1-Framework zu verwenden, um den Front-End-Wert abzurufen und einige Werte zurückzugeben, z Token. Verwenden Sie dann localStorage.setItem(), um die Daten im Frontend zu speichern. Bei nachfolgenden Besuchen wird der von localStorage.setItem () gespeicherte Wert an den Hintergrund zurückgegeben, sodass der Hintergrund den entsprechenden Wert abrufen, den Wert der Datenbank basierend auf diesem Wert abrufen und schließlich feststellen kann, ob der Wert festgelegt ist. Die erfolgreiche oder fehlgeschlagene Anweisung oder Der Wert wird an das Frontend zurückgegeben. Das Frontend implementiert eine Operation oder einen Sprung basierend auf dem erhaltenen Wert.

1. Bereiten Sie den Aufruf von vue.js und axios.js im Front-End login.html vor. Hier werden auch einige einfache UI-Anwendungen von Are You Hungry genannt.

<script src="https://cdn.staticfile.org/vue/2.4.2/vue.min.js"></script>//vue.js的使用
<script src="https://unpkg.com/axios/dist/axios.min.js"></script>//axios的使用

<link rel="stylesheet" href="https://unpkg.com/element-ui/lib/theme-chalk/index.css">
<script src="https://unpkg.com/element-ui/lib/index.js"></script>//饿了吗ui js和css的调用。

Detaillierte Verwendung von vue.js und axios.js. Einzelheiten finden Sie im https://cn.vuejs.org/v2/guide/ vue.js-Tutorial und im https://www.kancloud.cn/yunye/axios/234845

axios.js-Tutorial. Der Front-End-Wertübergabecode login.html lautet wie folgt:

<script>//返回信息到前端
		
			const app = new Vue({
				el: &#39;#app&#39;,//对应使用id="app"获取信息。
				data() {
					return {
						admin: "",
						password: "",
						dd:"",//定义是三个变量初始化都为空可在id="app"的页面编写{{admin}}返回admin的值
					}
				},
				methods: {//参数的传递
					login: function () {
						var $this = this;
						console.log("登录触发");//打印返回
						axios({
						method: &#39;post&#39;,
						url: &#39;http://127.0.0.1/xiangbb/tp5/public/user&#39;,
						data: {
							admin: this.admin,
							password: this.password
						}
						})//使用axios根据地址把data的数组值根据post进行传输,this.admin和this.password是定义<input v-model="admin">获取
						.then(function (response) {//成功400或401 执行。
							//$this.dd = response.data;//获取后台数据
							//console.log(response.data.access_token);
							localStorage.setItem(&#39;token&#39;, response.data.access_token);//本地存储token值
							window.location.href="../index/index.html";//跳转页面
						})
						.catch(function (error) {
							$this.$message.error(&#39;账号或密码错误!&#39;);//失败,出现错误,返回弹窗
							console.log(error);

						});

					}
				},
				mounted() {//在模板渲染成html后调用,这里未使用,配套的created在模板渲染成html前调用
					
				}
			})
		</script>

Sie müssen auch die Konfigurationsdatei app.php einrichten

&#39;default_return_type&#39;    => &#39;json&#39;,

Eine Verbindung zur Datenbank in Datenbank.php herstellen

Das Folgende ist der Hintergrund, den Sie erhalten müssen Daten verarbeiten und mit den Daten arbeiten. Dabei werden hauptsächlich die Anforderungen und Modelle von tp5.1 sowie die Verwendung von jwt verwendet. Weitere Informationen finden Sie unter https://github.com/firebase/php-jwt

<?php
namespace app\index\controller;//表示放置位置
use think\Controller;//控制器基类
use \Firebase\JWT\JWT;//调用库  jwt 类
use think\Request;//请求对象类
use app\common\model\User as Muser;//模型
class User extends Controller
{
    public function user()
    {
        
        //echo $_COOKIE["user"];//前端传参到这里
        $admin=input(&#39;post.admin&#39;);
        $password=input(&#39;post.password&#39;);//获取前端
        $user=db(&#39;user&#39;)->where(&#39;admin&#39;,$admin)->where(&#39;password&#39;,$password)->find();//删选
        //\dump($user);
        if($user)//使用jwt方法
        {
            $key = \config("app.jwt_key");//key值,唯一保密,在config的app下的jwt_key
            $token = array(
                "iss" => "http://127.0.0.1/xiangbb/tp5/public/user",//  签发地址
                "aud" => "http://127.0.0.1/xiangbb/qian/login/login.html#",//面向对象地址
                "iat" => time(),//创建时间
                "nbf" => time(),//生效时间
                &#39;exp&#39; => time() + 3600, //过期时间-10min
                &#39;sub&#39; => $user[&#39;id&#39;],//传递的id值
            );
            
            $jwt = JWT::encode($token, $key);//加密
            //$decoded = JWT::decode($jwt, $key, array(&#39;HS256&#39;));//解密
            return [
                "access_token" => $jwt,//加密数据
                "token_type" => "Bearer",//类别
                "expires_in" => 3600,// 过期时间
            ];//返回数组

        }
        return response()->code(401);//如找不到  返回401指令
    
    }
}

Der Hintergrund User.php basiert auf dem erhaltenen Daten und die Datenbank vergleichen, aber wenn das Kontokennwort korrekt ist, wird eine Zeichenfolge mit der eindeutigen ID dieses Kontos und anderen Daten an das Frontend zurückgegeben. Das Frontend speichert den Wert und verwendet den Wert, um die entsprechenden Daten abzurufen dem Benutzer und zeigt es im Frontend an. Rufen Sie diese JS auf, und dann lautet der JS-Code wie folgt:

	<script>
		const app = new Vue({
				el: &#39;#app&#39;,
				data() {
					return {
						
						token: "",
						http: {},
						}
						
						
					},
				methods: {
				},
				created() {
				
					this.token = localStorage.getItem(&#39;token&#39;);//在登录页面验证成功而保存的token值,进行获取
					this.http = axios.create({//整理token的值
							
							baseURL: &#39;http://127.0.0.1/xiangbb/tp5/public/&#39;,
							timeout: 5000,
							headers: {&#39;Authorization&#39;: "Bearer "+this.token}
					});
					if(!this.token)//若this.token不存在时返回登录页面
					{
						window.location.href="../login/login.html";
					}
					else
					{
						this.http.get(&#39;/user&#39;)//调用上面的http,把值传回后台
						.then(function (response) {
							console.log(response);
						})
						.catch(function (error) {//token错误返回登录页面
							window.location.href="../login/login.html";
							console.log(error);
						});
					}
				}
			})
	</script>

Route route.php empfängt ihn und springt zur Middleware, um den übergebenen Wert zu überprüfen und zu bestimmen, ob der Controller eingegeben und nachfolgende Vorgänge ausgeführt werden sollen Dies erleichtert später die Feststellung, dass nicht für jede Funktion des Controllers Methoden geschrieben werden müssen.

Route::rule(&#39;user&#39;,&#39;index/user/show&#39;,&#39;GET&#39;)->middleware(&#39;verify_user&#39;);//路由接收,跳转中间件判断

Der VerifyUser.php-Code der Middleware lautet wie folgt:

<?php

namespace app\http\middleware;//文件位置
use think\Request;//请求
use \Firebase\JWT\JWT;//jwt
use app\common\model\User;//模型
class VerifyUser
{
    public function handle(Request $request, \Closure $next)//使用模型
    {
        $Authorization = $request->header(&#39;Authorization&#39;);//获取前端传递的值
        if(!isset($Authorization)) return response()->code(401);//检测变量是否存在,不存在返回401
        $key =\config("app.jwt_key");//key值 定义在config下的app的jwt_key
        $token_type = \explode(" ",$Authorization)[0];//根据空格隔开获取第零个字符串
        $token = \explode(" ",$Authorization)[1];//根据空格隔开获取第一个字符串
        
        if($token_type == &#39;Bearer&#39;)//判断$token_type是否正确
        {
            
            try {
                $decoded = JWT::decode($token, $key, array(&#39;HS256&#39;));//解密
                $request->user = $user = User::get($decoded->sub);//获取解密后的用户id
                if(!$user||$decoded->exp<time())//如果id不存在或者时间超出,返回401
                    return response()->code(401);
            }catch(\Exception $e) { //捕获异常,返回401,可能解密失败,$e可返回失败原因
                return response()->code(401);
                }
        }
        else {//$token_type错误也返回401
            return response()->code(401);
        }
        return $next($request);//当没有执行401时,执行到下一个请求,可能有多个中间件或者路由。
    }
        
}

Wenn die Middleware ausgeführt wird, springt sie zum Controller User.php

    public function show(Request $request)//请求,依赖注入
    {
       $user = Muser::get($request->user[&#39;id&#39;]);//  模型,获取数据库id相同的表数据,默认表名为Muser的原名 User
       return $user;//返回对应数据
    }

An diesem Punkt erfolgt eine einfache Front-End- und Back-End-Trennung von Konto und Die Eingabe des Passworts und die Anmeldung sind abgeschlossen. Der Code ist möglicherweise nicht streng genug und muss optimiert werden.

Das obige ist der detaillierte Inhalt vonthinkphp5.1 realisiert die Front-End- und Back-End-Trennung sowie die Interaktion mit PHP und vue.js. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:csdn.net. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen