Heim >PHP-Framework >Denken Sie an PHP >So kombinieren Sie VueJs mit Thinkphp

So kombinieren Sie VueJs mit Thinkphp

(*-*)浩
(*-*)浩Original
2019-07-15 09:55:2321154Durchsuche

Wenn Vue auf dem Server bereitgestellt wird, wissen wir alle, dass die über den Befehl npm run build gepackte dist-Datei direkt durchsucht werden kann, indem man sie über http angibt. Thinkphp kann nur durchsucht werden, indem auf index.php verwiesen wird Datei über den Domänennamen. Damit das Front-End die Back-End-Daten normal aufrufen kann.

So kombinieren Sie VueJs mit Thinkphp

Es gibt zwei Methoden:

1. Das Front-End ruft zurück. Enddaten domänenübergreifend.

2. Die Front-End-Paketdatei wird im Back-End-Serverordner (gleiche Domäne) bereitgestellt.

Webserver: Apache

Zum Beispiel: domänenübergreifend

Konfigurieren Sie die Site auf dem Server:

在路径/home/www/  下创建test项目文件夹,用来放项目文件。
找到httpd-vhosts.conf文件配置站点
前端站点:
<VirtualHost *:80>
    ServerName test.test.com
    DocumentRoot "/home/www/test/dist"  
    DirectoryIndex index.html
</VirtualHost>
后端站点:
<VirtualHost *:80>
    ServerName test.testphp.com
    DocumentRoot "/home/www/test/php"  
    DirectoryIndex index.php
</VirtualHost>

Verpacken Sie das Frontend. Die gute dist-Datei wird im Ordner /home/www/test/ abgelegt und kann durch Ausführen von http://test.test.com durchsucht werden. Wenn sich der Pfad ändert, wird beim Aktualisieren ein 404-Fehler angezeigt. Erstellen Sie zu diesem Zeitpunkt eine .htaccess-Datei unter der dist-Datei. Wenn der Pfad nicht vorhanden ist, kann dieses Problem durch Verweisen auf http://test.test.com/index.html gelöst werden.

<IfModule mod_rewrite.c>
  RewriteEngine On
  RewriteBase /
  RewriteRule ^index\.html$ - [L]
  RewriteCond %{REQUEST_FILENAME} !-f
  RewriteCond %{REQUEST_FILENAME} !-d
  RewriteRule . /index.html [L]
</IfModule>

Erstellen Sie den PHP-Ordner des Projektstammverzeichnisses im Ordner /home/www/test und platzieren Sie die thinkphp-Datei unter PHP. Die Eintragsdatei von TP5 befindet sich unter der öffentlichen Datei. Verschieben Sie hier die Eintragsdatei index.php unter public in den PHP-Ordner (meine persönliche Angewohnheit ist es, die Eintragsdatei im Projektstammverzeichnis abzulegen) und binden Sie das Indexmodul daran Backend.

Das Front-End ruft die Back-End-Schnittstelle auf, es gibt domänenübergreifende Lösungen und es gibt mehrere domänenübergreifende Lösungen. Hier werde ich das Back-End-PHP konfigurieren, um das domänenübergreifende Problem zu lösen Legen Sie die domänenübergreifende Konfiguration im öffentlichen Controller fest:

class Common extends Controller
{
    public $param;
    // 设置跨域访问
    public function _initialize()
    {
        parent::_initialize();
        isset($_SERVER['HTTP_ORIGIN']) ? header('Access-Control-Allow-Origin: '.$_SERVER['HTTP_ORIGIN']) : '';
        header('Access-Control-Allow-Credentials: true');
        header('Access-Control-Allow-Methods: GET, POST, PUT, DELETE, OPTIONS');
        header("Access-Control-Allow-Headers: Origin, X-Requested-With, Content-Type, Accept, authKey, sessionId");
        $param =  Request::instance()->param();
        $this->param = $param;
    }
}

Das Frontend ruft die Anmeldeschnittstelle auf: this.axios.post('http://test.testphp.com/index.php/base/ login', {Benutzer: '', Passwort: ''}).

(Die Schnittstelle kann unter der Datei webpack.base.conf.js definiert werden: http://test.testphp.com/index.php/)

Gleiche Domäne

Die Backend-Konfiguration ist dieselbe wie oben, und die Anmerkung zur Header-Konfiguration im öffentlichen Konfigurator ist dieselbe. Platzieren Sie alle Dateien unter der Front-End-Dist-Datei (einschließlich .htaccess) im PHP-Ordner. Leiten Sie den Pfad der Indexmethode des Back-End-Index-Controllers zur Datei index.html unter PHP um:

namespace app\index\controller;
use think\Controller;
class Index extends Controller
{
    public function index() {
        $this->redirect('/index.html');
}

Das Front-End ruft die Anmeldeschnittstelle auf: this.axios.post('/index.php /base/login', {Benutzer: '', Passwort: ''})

Weitere technische Artikel zu Thinkphp finden Sie in der Tutorial-Spalte Thinkphp, um mehr zu erfahren!

Das obige ist der detaillierte Inhalt vonSo kombinieren Sie VueJs mit Thinkphp. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn