Mac极简的开发环境Laravel Valet实践
Laravel Valet 是一个 Mac 下面的极简的开发环境,不但可以本地开发,还可以分享到公网访问,当你的电脑开机后会在后台一直启动 Caddy , Valet 通过 DnsMasq 把所有的 .dev 域名指向你本地安装的站点,比如站点所在目录 blog , 通过浏览器访问 blog.dev 就会自动访问到 blog 了。分享到公网其实主要依靠 ngrok 来实现的。
先来安装一下
- 更新 Homebrew
brew update
- 确保 brew services 可用
brew services list
- 安装 php70 如果没有安装的话
brew install php70
- 确保 ~/.composer/vendor/bin 已经添加到系统PATH目录中
- 安装 Valet
composer global require laravel/valet
- 安装 Valet 和 DnsMasq
valet install
如果上一步出现下面的错误:
[ReflectionException] Class Fxp\Composer\AssetPlugin\Repository\NpmRepository does not exist
这是由于 Composer\Repository\ComposerRepository::whatProvides API 更新了,你已经全局安装了 fxp/composer-asset-plugin ,所以你需要更新一下:
composer global require fxp/composer-asset-plugin --no-plugins
如果 DnsMasq 安装失败的话手动安装一下
brew install dnsmasq
- Ping一下 *.dev ,如果Ping通了说明就OK了
⇒ ping *.devPING *.dev (127.0.0.1): 56 data bytes 64 bytes from 127.0.0.1: icmp_seq=0 ttl=64 time=0.040 ms 64 bytes from 127.0.0.1: icmp_seq=1 ttl=64 time=0.065 ms 64 bytes from 127.0.0.1: icmp_seq=2 ttl=64 time=0.064 ms 64 bytes from 127.0.0.1: icmp_seq=3 ttl=64 time=0.062 ms
下面来启动一个 Valet 站点
目前直到 1.1.7 版本支持的驱动如下:
- Laravel
- Lumen
- Symfony
- Zend
- CakePHP 3
- WordPress
- Bedrock
- Craft
- Statamic
- Jigsaw
- Wordpress
- Joomla
- Contal
- Sculpin
- Static HTML
当然,你也是可以自己驱动, Custom Valet Drivers
- 创建一个文件夹
mkdir ~/WebRoot/ValetSite && cd ~/WebRoot/ValetSite
- 运行 park 命令,把上面的目录作为寻找站点路径
valet park
- 创建一个Laravel驱动的站点
laravel new blog
- 浏览器访问 http://blog.dev 就OK了
关于 link 命令
link 命令也可以用来启动 Laravel 站点。 park 命令会把这个目录下所有文件夹都当做独立的不同站点,而当你只需要启动一个站点的时候,可以使用 link 命令。
cd ~/WebRoot/ValetSite/blog valet link test-blog
执行上面命令就可以通过 http://test-blog.dev 访问项目站点了,还有两个有用的命令:
valet links valet unlink
一看就知道干嘛用的了
让站点支持TLS
让站点支持TLS也很简单,自需要执行:
valet secure blog
这样就可以用 https://blog.dev 进行访问了,取消的话:
valet unsecure blog
分享站点
这个需求其实挺实用,比如自己开发的东西需要让别人通过外网访问到,只需要一个简单的命令就可以了
valet share
这样就会通过 ngrok 生成一个外网URL,要停止分享,可以按 Control + C 来取消进程。
ngrok by @inconshreveable (Ctrl+C to quit)Tunnel Status online Version 2.0.25/2.1.1 Region United States (us) Web Interface http://127.0.0.1:4040 Forwarding http://fda651a8.ngrok.io -> blog.dev:80 Forwarding https://fda651a8.ngrok.io -> blog.dev:80Connections ttl opn rt1 rt5 p50 p90 0 0 0.00 0.00 0.00 0.00
查看站点日志
如果你想查看所有站点的日志,让新的日志也会自动的展示在终端中只需要执行 valet logs
其实还有一个隐藏的控制台:访问 http://localhost:4040/inspect/http
还有一些 Valet 命令
命令 | 描述 |
---|---|
valet forget | 在 “parked” 的目录中执行该命令来把其从 parded 目录列表中删除。 |
valet paths | 查看所有 “parked” 路径 |
valet restart | 重启 Valet 程序 |
valet start | 启动 Valet 程序 |
valet stop | 停止 Valet 程序 |
valet uninstall | 卸载 Valet 程序 |
转载请注明:转载自 Ryan是菜鸟 | LNMP技术栈笔记
如果觉得本篇文章对您十分有益,何不打赏一下

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Alipay Php ...

JWT est une norme ouverte basée sur JSON, utilisée pour transmettre en toute sécurité des informations entre les parties, principalement pour l'authentification de l'identité et l'échange d'informations. 1. JWT se compose de trois parties: en-tête, charge utile et signature. 2. Le principe de travail de JWT comprend trois étapes: la génération de JWT, la vérification de la charge utile JWT et l'analyse. 3. Lorsque vous utilisez JWT pour l'authentification en PHP, JWT peut être généré et vérifié, et les informations sur le rôle et l'autorisation des utilisateurs peuvent être incluses dans l'utilisation avancée. 4. Les erreurs courantes incluent une défaillance de vérification de signature, l'expiration des jetons et la charge utile surdimensionnée. Les compétences de débogage incluent l'utilisation des outils de débogage et de l'exploitation forestière. 5. L'optimisation des performances et les meilleures pratiques incluent l'utilisation des algorithmes de signature appropriés, la définition des périodes de validité raisonnablement,

Le détournement de la session peut être réalisé via les étapes suivantes: 1. Obtenez l'ID de session, 2. Utilisez l'ID de session, 3. Gardez la session active. Les méthodes pour empêcher le détournement de la session en PHP incluent: 1. Utilisez la fonction Session_RegeReate_id () pour régénérer l'ID de session, 2. Stocker les données de session via la base de données, 3. Assurez-vous que toutes les données de session sont transmises via HTTPS.

L'application du principe solide dans le développement de PHP comprend: 1. Principe de responsabilité unique (SRP): Chaque classe n'est responsable d'une seule fonction. 2. Principe ouvert et ferme (OCP): les changements sont réalisés par extension plutôt que par modification. 3. Principe de substitution de Lisch (LSP): les sous-classes peuvent remplacer les classes de base sans affecter la précision du programme. 4. Principe d'isolement d'interface (ISP): utilisez des interfaces à grain fin pour éviter les dépendances et les méthodes inutilisées. 5. Principe d'inversion de dépendance (DIP): les modules élevés et de bas niveau reposent sur l'abstraction et sont mis en œuvre par injection de dépendance.

Comment définir automatiquement les autorisations d'UnixSocket après le redémarrage du système. Chaque fois que le système redémarre, nous devons exécuter la commande suivante pour modifier les autorisations d'UnixSocket: sudo ...

Comment déboguer le mode CLI dans phpstorm? Lors du développement avec PHPStorm, nous devons parfois déboguer PHP en mode interface de ligne de commande (CLI) ...

Liaison statique (statique: :) implémente la liaison statique tardive (LSB) dans PHP, permettant à des classes d'appel d'être référencées dans des contextes statiques plutôt que de définir des classes. 1) Le processus d'analyse est effectué au moment de l'exécution, 2) Recherchez la classe d'appel dans la relation de succession, 3) il peut apporter des frais généraux de performance.

Envoyant des données JSON à l'aide de la bibliothèque Curl de PHP dans le développement de PHP, il est souvent nécessaire d'interagir avec les API externes. L'une des façons courantes consiste à utiliser la bibliothèque Curl pour envoyer le post� ...
