1. Fendo181

    No comment

    Fendo181
Changes in body
Source | HTML | Preview
@@ -1,599 +1,603 @@
この記事には以下の内容が含まれています。
- Laravel HomesteadによるLaravel5.2の環境構築
- 環境構築から一通りのLaravelの動作確認
- local開発環境から実際に公開する迄の設定
#開発環境
|OS|windows8.1 64bit,windows 10 64bit|
|:--|--:|
|vagrant|ver 1.8.5|
|Oracle VM VirtualBox|バージョン 5.0.26|
|git|ver 2.8.|
既にvagrantとVMが導入されているのを前提で話を勧めます。
>
- Vagrant
https://www.vagrantup.com/
- Vagrantの解説(naoyaさんのはてなダイアリー)
http://d.hatena.ne.jp/naoya/20130205/1360062070
- Windowsを使用している場合は、ハードウェア仮想化(VT-x)を有効にする必要があります。通常、BIOSにより有効にできます。
#__LaravelHomesteadtとは?__
![laravel-homestead1.png](https://qiita-image-store.s3.amazonaws.com/0/64829/3760ce22-f7b1-2a68-53b1-e8bc7d1b21b8.png)
Larabel Homesteadを理解するには[公式](https://laravel.com/docs/5.2/homesteadl)からの謳い文句を見れば容易に理解できます。
>
Laravel Homestead(入植農地、「ホームステード」)はパッケージを事前に済ませた、Laravel公式の"box"で、PHPやHHVM、Webサーバー、その他のサーバーソフトウェアをローカルマシンにインストールする必要なく、素晴らしい開発環境を準備できます。オペレーティングシステムでごちゃごちゃになる心配はもうありません! Vagrantのboxは完全に使い捨てできます。何かの調子が悪くなれば壊して、数分のうちにそのboxを再生成できます!
今回はLaravel Homesteadを使いましたが、例えば[cent os 6.xに1からComposerで導入する](http://qiita.com/yuppi/items/d5da1c15ae70f4b0abbb)方法や、[windowsにxamppを入れてからComposerを導入してからLaravel5を始める方法](http://w.builwing.info/2015/05/14/xampp%E3%81%ABlaravel5%E3%81%AE%E3%82%A4%E3%83%B3%E3%82%B9%E3%83%88%E3%83%BC%E3%83%AB/)など、開発環境を用意する方法はLaravel Homesteadだけではないです。御自身の環境に合わせて最適なtoolを使って下さい。
Laravel Homesteadに含まれるソフトウェアは以下になります。
>
公式より(https://laravel.com/docs/5.2/homestead)
Ubuntu 14.04
PHP 5.6 / 7.0
HHVM
Nginx
MySQL
Postgres
Node (PM2とBower、Grunt、Gulpを含む)
Redis
Memcached (PHP 5.xのみ)
Beanstalkd
Laravel Envoy
Blackfire Profiler
実際に開発環境を立ち上げた際のphpのversionを調べた結果は以下になります。
+※2016年7月23日現在
+
````php-v:php
-PHP 7.0.3-13+deb.sury.org~trusty+1 (cli) ( NTS )
+PHP 7.0.8-2+deb.sury.org~xenial+1 (cli) ( NTS )
Copyright (c) 1997-2016 The PHP Group
Zend Engine v3.0.0, Copyright (c) 1998-2016 Zend Technologies
- with Xdebug v2.4.0RC4, Copyright (c) 2002-2016, by Derick Rethans
- with blackfire v1.9.2, https://blackfire.io, by Blackfireio Inc.
+ with Zend OPcache v7.0.8-2+deb.sury.org~xenial+1, Copyright (c) 1999-2016, by Zend Technologies
+ with blackfire v1.10.6, https://blackfire.io, by Blackfireio Inc.
+
+
````
+
という事なので今現在のLaravel Homestead5.1を導入すればもれなくphp7の開発環境を整える事が可能です。
#__Laravel HomeSteadの導入__
基本[公式](http://readouble.com/laravel/5/1/ja/homestead.html)をみてそのまま、導入すれば大丈夫です。何かerrorが起きた場合も公式を振り返って下さい。
- 1 vagrantにlaravel homestead boxを追加
````
vagrant box add laravel/homestead
````
- 2 Homesteadリポジトリーをgit cloneしてくる。
````
git clone https://github.com/laravel/homestead.git Homestead
````
- 3 cloneしてきたHomeSeadリポジトリーにint.shを生成
````
cd Homestead
bash init.sh
````
>
すでに~/.homesteadディレクトリーの中にHomestead.yamlファイルがあるなら、init.shスクリプトを実行する必要はありません。しかし、初めてコンピューターにHomesteadをインストールした場合には、新しいHomesteadディレクトリーでbash init.shを実行する必要があります。
細かい点を大分端折ってしまいましたが、以上で一通りの導入は可能となります。
1番目のboxを追加する部分に一番時間がかかった気がします。
#__設定について__
##鍵を作る。
クライアントからVMに接続する為にwinodws for gitの機能を使って鍵を作りましょう。
ssh鍵を保存するためのディレクトリを作成して移動します。
Git_Bash上で以下のコマンドを実行して下さい。
```
mkdir ~/.ssh
cd ~/.ssh
```
Git_Bash
```
ssh-keygen -t rsa -C 自分のメールアドレス
```
##Homstead.yamlファイルを探す。
次に``Homestead.yam``を設定しますが、以下のリンク先の方で詳細に書かれていますので、こちらを参考にして下さい。
[Laravel Homesteadを使ってみよう!](http://qiita.com/syossan27/items/0104615e5f9ae26f0720)
~/.homesteadディレクトリ直下にあります。もし、表示されなければ隠しフォルダの設定をいじって見てください。
````
cd ~/.homestead/
vim Homestead.yaml
````
Homestead.ymlの中身
````
---
//基本ここはデフォルトで大丈夫
ip: 192.168.00.00 //example
memory:
cpus:
provider:
//公開鍵の場所
authorize: ~/.ssh/id_rsa.pub
//秘密鍵の場所
keys:
- ~/.ssh/id_rsa
//C直下にlaravelのプロジェクトを作成した場合
folders:
- map: C:/laravel_APP/Homestead/Code
to: /home/vagrant/Code
//pubicディレクトリの設定
sites:
- map: homestead.app
to: /home/vagrant/Code/Laravel/public
databases:
- homestead
````
###**※追記(2016_7_22)**
```
folders:
- map: C:/laravel_APP/Homestead/Code
```
ここのpathですが`Code`ディレクトリが無い場合、`vagrant up`時にErrorが出ます。
従って
```
cd Homestead
mkdir Code
```
でCodeディレクトリを作っておいて下さい。
その後にもう一度`bash init.sh`を実効して下さい。
>参考
[Laravel Homestead - The host path of the shared folder is missing: ~/Cod](http://stackoverflow.com/questions/28833673/laravel-homestead-the-host-path-of-the-shared-folder-is-missing-code)
[The host path of the shared folder is missing: ~/Code]
(http://stackoverflow.com/questions/28558113/the-host-path-of-the-shared-folder-is-missing-code)
##etc/hostにIPアドレスを追加
windowsユーザだとわかりにくいですが、hostファイルは`:¥windows¥system32¥drivers¥etc`にあります。hostファイルを編集する場合は管理者権限に変更してから書き換えて下さい。
hostファイルを開いた後にHomestead.ymlに記載されているipアドレスを以下の様に追加して下さい。
````
# Copyright (c) 1993-2009 Microsoft Corp.
#
# This is a sample HOSTS file used by Microsoft TCP/IP for Windows.
#
# This file contains the mappings of IP addresses to host names. Each
# entry should be kept on an individual line. The IP address should
# be placed in the first column followed by the corresponding host name.
# The IP address and the host name should be separated by at least one
# space.
#
# Additionally, comments (such as these) may be inserted on individual
# lines or following the machine name denoted by a '#' symbol.
#
# localhost name resolution is handled within DNS itself.
# 127.0.0.1 localhost
# ::1 localhost
192.168.00.00 homestead.app //追加
````
参考文献
>
[Windows7でhostsファイルを書き換える](http://negiwatch.jugem.jp/?eid=54)
以上で一通りの設定は完了しました。
設定完了後はVagrantfileが置かれているディレクトリに移りvagrant upしましょう。
````
vagrant up
````
##**(追記 2016_7_23)** 仮想環境側でLaravelプロジェクトを作る。
状況説明
(windows10にアップグレードした後以前のLaravelのプロジェクトを全て破棄した後に、再度環境構築をしたら、`vagrant up`後にCodeディレクトリにソースコードもなく、192.168.10.10にアクセスしてもダメだった)
以前は`vagrant up`したらそのまま、すぐにLaravelプロジェクトが出来たはずですが、昨日から全然この先がうまくいか`vagrant destroy --forced`を繰り返していく内に解決したので追記。
```
#vagrantにssh接続
vagrant ssh
#VM上のローカル共有ディレクトリに移動
cd Code/
#conposerが最新のバージョンか確認、最新じゃなかったらアップデートをかける
sudo composer self-update
#プロジェクト作成
composer create-project laravel/laravel Laravel
```
これで最後までいけば、Laravelプロジェクトが無時にインストールされました。
>参考
[Windows10でLaravel Homestead環境構築](http://qiita.com/ricoirico/items/9745160bcf9983fa30ad)
URLに[http://homestead.app/](http://homestead.app/)か[http://192.168.00.00/](http://192.168.10.10/)にアクセスするとLaravelの画像が表示され環境構築が完了しました。お疲れ様です。
![Top.png](https://qiita-image-store.s3.amazonaws.com/0/64829/f24eb62f-c68d-78ec-2b5d-3a384019e974.png)
一応動作確認として`~/pubulic/`直下に
```php:phpinfo.php
<?php
phpinfo();
?>
```
とファイルを作ってあげて[http://192.168.00.00/phpinfo.php](http://192.168.10.10/phpinfo.php)でアクセスしてみてちゃんとphpの情報が出れば大丈夫です。![php.png](https://qiita-image-store.s3.amazonaws.com/0/64829/9452cd20-2f48-9a2d-82ef-d4a7589a715f.png)
#__公開する用の簡単なwebアプリケーション作成__
公開するにあたって今回は簡単な[簡易掲示板](http://dotinstall.com/lessons/bbs_php_v2)を作成してみます。workディレクトリを作成して、下に`index.php`を作成しましょう。
`~/public/work/index.php`
```php:index.php
<?php
$dateFile = 'bbs.dat';
session_start();
function setToken(){
$token = sha1(uniqid(mt_rand(),true));
$_SESSION['token'] = $token;
}
function checkToken(){
if(empty($_SESSION['token']) || ($_SESSION['token'] != $_POST['token'])){
echo "不正なPOSTが行われました!";
exit;
}
}
function h($s){
return htmlspecialchars($s,ENT_QUOTES,'UTF-8');
}
if($_SERVER['REQUEST_METHOD']=='POST' && isset($_POST['message']) && isset($_POST['user'])){
checkToken();
$message = trim($_POST['message']);
$user = trim($_POST['user']);
if($message !== ''){
$user = ($user === '') ?'名無しのAさん' :$user;
$message =str_replace("\t", ' ',$message);
$user =str_replace("\t", ' ',$user);
$postesAt=date('Y-m-d H:i:s');
$newDate = $message ."\t".$user."\t".$postesAt."\n";
$fp =fopen($dateFile,'a');
fwrite($fp,$newDate);
fclose($fp);
}
} else{
setToken();
}
$posts=file($dateFile,FILE_IGNORE_NEW_LINES);
$posts = array_reverse($posts);
?>
<!DOCTYPE html>
<html lang="ja">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<!-- Bootstrap -->
<link rel="stylesheet" media="screen" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.5/css/bootstrap.min.css">
<title>簡易掲示板</title>
</head>
<body>
<div class="container">
<h1>簡易掲示板</h1>
<form action="" method="post">
message:
<input type="text" name="message"> user :
<input type="text" name="user">
<input type="submit" value="投稿">
<input type="hidden" name="token" value="<?php echo h($_SESSION['token']); ?>" >
<h4>userに何も入力が無ければ「名無しのAさん」で投稿されます。</h4>
</form>
<h2>投稿一覧 (<?php echo count($posts); ?>件)</h2>
<ul>
<?php if (count($posts)) : ?>
<?php foreach ($posts as $post) :?>
<?php list($message,$user,$postesAt)=explode("\t",$post); ?>
<li><?php echo h($message); ?> <?php echo h($user); ?>-<?php echo h($postesAt); ?></li>
<?php endforeach; ?>
<?php else : ?>
<li>投稿はまだありません</li>
<?php endif; ?>
</ul>
</div>
</body>
</html>
```
後は書き込み用の`bbs.dat`を生成します。ディレクトリ構造は以下の様になります。
```
vagrant@homestead:~/Code/Laravel/public$ tree
├── phpinfo.php
└── work
├── bbs.dat
└── index.php
```
上手くいけば[192.168.00.00/work/index.php](192.168.00.00/work/index.php)にアクセスする事で下の画面が表示されます。
![bbs.png](https://qiita-image-store.s3.amazonaws.com/0/64829/2f177ab7-4044-6e3f-e6ea-5cae2fed71fa.png)
以上で簡単なwebアプリケーションを作成する事ができました。
次はこれを実際にレンタルサーバを借りて公開しましょう。
#__作成したwebアプリケーションを公開する__
今回レンタルサーバを借りて公開しましたが、すぐに公開したいって方には[Heroku](https://dashboard.heroku.com/)でデプロイしても十分可能です。
>
[初心者でも15分で公開できるHerokuのはじめかた](http://developers.mobage.jp/blog/how-to-use-for-beginners-heroku)
Herokuで公開する場合、一定時間のアクセスがなければスリープしてしまう為、簡易掲示版の内容を書きこんだ`bbs.dat`の中身も全て消えてしまう点に注意して下さい。
>
[Herokuへ定期的にアクセスしてスリープさせないアプリ「heroku patroller」を作りました。](http://qiita.com/yoshioota/items/620b004eb320a8d8a29c)
[HubotをHerokuのFree dynoに対応させる](http://blog.spacemarket.com/code/hubot-on-heroku-free-dyno/)
##レンタルサーバを借りる。
今回レンタルサーバを借りるにあたって、[ロリポップ!](https://lolipop.jp/)を選択しました。
![R0000000073.jpg](https://qiita-image-store.s3.amazonaws.com/0/64829/c08d7ce0-7e69-284d-89fe-02ef9392e9e8.jpeg)
理由としては
- 登録後10日間は無料で使える
- 安定性がある
- 管理画面が見やすい
等々ありますが、初心者である自分にとっても使いやすと思い選択しました。
今回はデータベースを使わないアプリケーションなので、一番安いエコノミープランでいいですが、MySQLと連携させたサービスを考えようとするとライトプラン以上になります。各自好きなプランを選んでドメインを取得して下さい。
詳細は以下のURLからご確認下さい。
>
[ロリポップ!レンタルサーバプラン比較表](https://lolipop.jp/service/about/)
また現在ライトプランにおけるPHPのversionは以下になります。
![rori_php.png](https://qiita-image-store.s3.amazonaws.com/0/64829/efd566b6-b3d4-749a-5082-d6302cc1f96d.png)
※ここから先は既にドメンを取得した前提で話を進めます。
##.envの設定
LaravelHomesteadではデフォルトで[PHP DotEnv](https://github.com/vlucas/phpdotenv)がインストールされています。PHP DotEnvとは何かというと、通常vagrantやxamppでもそうですが、ローカル開発環境時の環境変数をそのままにした状態でいざ、実際の開発環境に持っていくと環境変数が全然あわない問題が発生します。しかもそれが1つのファイルだけだといいですが、複数あると一つ一つのファイルを書き直さないといけない上にバグも生みやすくなります。そこで[PHP DotEnv](https://github.com/vlucas/phpdotenv)を使う事で、__どの環境でも共通の方法で環境変数を参照出来る事が可能__になります。
実際に.envファイルを見てみるとわかりやすいです。
```php:.env
APP_ENV=local
APP_DEBUG=true
APP_KEY=****
APP_URL=http://localhost
DB_CONNECTION=mysql
DB_HOST=****
DB_PORT=***
DB_DATABASE=****
DB_USERNAME=****
DB_PASSWORD=****
CACHE_DRIVER=file
SESSION_DRIVER=file
QUEUE_DRIVER=sync
REDIS_HOST=***
REDIS_PASSWORD=***
REDIS_PORT=***
MAIL_DRIVER=smtp
MAIL_HOST=***
MAIL_PORT=***
MAIL_USERNAME=null
MAIL_PASSWORD=null
MAIL_ENCRYPTION=null
```
従って今回はローカル開発環境から公開用に設定するのは以下の2項目だけで十分となります。
`APP_URL`にはアカウント情報からロリポップ!のドメイン名を入力して下さい。
![domain_name.png](https://qiita-image-store.s3.amazonaws.com/0/64829/f26a36db-0a03-95cb-afa7-cd8536c2fc6b.png)
```php:.env(公開)
APP_ENV=staging /*localからstagingに変更*/
APP_URL=http://abcdef.test.jp/ /* ロリポップ!のドメイン名を入力*/
```
また今回はMySQLを使ったアプリケーションを紹介しておりませんが、MySQLも同様に御自身の環境に合わせて`DB_`以下の環境変数を合わせる事でデータベースにアクセスする事が可能となります。
_注意_
なお、本番環境でDocumentRootの下に.envを置くと、__当然ブラウザからアクセス__できてしまうので、.envだけ403 Forbiddenになるようにしておくか、DocumentRootの上に置くように設計しておいたほうがいいでしょう。
参考文献
>
[コード改善に役立ちそうなPHPライブラリ・ツール](http://qiita.com/ryu22e/items/bc87f2106e5db463462a)
[Laravel 5.0.dev 設定](http://readouble.com/laravel/5/0/dev/ja/configuration.html)
##FTP(公開サーバ)にファイルをコピーする。
ドメイン取得後公開サーバにアクセスします。ソフトウェアなんでもいいです。今回私は[アヒルちゃん](https://cyberduck.io/index.ja.html?l=ja)を使いました。アヒルちゃんをつかって公開サーバにアクセスする方法は以下を参照して下さい。
>
[Cyberduckを使った設定方法をご説明します](https://lolipop.jp/manual/hp/w-cyberduck/)
コピーするファイルは以下になります。
````
vagrant@homestead:~/Code/Laravel$ tree -La 1
.
├── app
├── artisan
├── bootstrap
├── composer.json
├── composer.lock
├── config
├── database
├── .env
├── .env.example
├── .gitattributes
├── .gitignore
├── gulpfile.js
├── package.json
├── phpunit.xml
├── Procfile
├── public
├── readme.md
├── resources
├── server.php
├── storage
├── tests
└── vendor
````
以上のファイルをFTPサーバ側にそのままコピーして下さい。
今回は一応わかりやすい様に、worksディレクトリの下にlaravelディレクトリを作りその下にコピーしました。
````
├── works
│   ├── laravel
├── app
├── artisan
├── bootstrap
├── composer.json
├── composer.lock
├── config
├── database
├── .env //.htaccesでアクセスしないように設定をして下さい!
├── .env.example //コピーしなくてもいい
├── .gitattributes //コピーしなくてもいい
├── .gitignore //コピーしなくてもいい
├── gulpfile.js
├── package.json
├── phpunit.xml
├── Procfile
├── public
├── phpinfo.php
├── work
├── index.php
├── bbs.dat
├── readme.md
├── resources
├── server.php
├── storage
├── tests
└── vendor
````
一応動作確認としてpublic直下に先ほど作った`phpinfo.php`にアクセスして結果を見てみましょう。
[http://ドメイン名/works/laravel/public/phpinfo.php](http://ドメイン名/works/laravel/public/)
もしphpのversionが正しく表示できない場合、管理者画面からphpのCGIの設定をいじってみて下さい。逆に正常に表示できればお疲れ様です。これで貴方が製作したwebアプリケーションが世界中の人に公開されました。
試しに
[http://ドメイン名/works/laravel/public/work/index.php](http://ドメイン名/works/laravel/public/)にアクセスして先ほど作成した簡易掲示板が表示できている事を確認して下さい。
#__終わりに__
ここまで来れば後はローカルの開発環境と同じようにpublic直下に簡単な練習用のwebアプリケーションを作ったり出来ますが、それだったら__わざわざLaravelを導入した意味がありません!。__今回はLaravelの機能をゴリゴリ活用したアプリケーションの紹介よりも、webアプリケーションを公開する方法を載せましたが、今後データベースを使った本格的なwebアプリケーションを作る際にはLaravelという素晴らしいフレームワークが大いに役たちます。その前準備としての紹介記事でした。
_余談_
この記事を書いた筆者は駆け出し中のプログラマーですので至らない部分が多々ありますし、分かりづらい部分が多いと思います..。なのでもし違っていたり、よく分からん!って方は遠慮なくコメントをお願いします。