SQLの窓

2013年11月08日


Windows PHP : SSH(Secure Shell)を使用して、ファイルをアップロード・ダウンロードする

PHP で セキュアなファイル転送を行う為に、SSH経由の SCP、SFTP を使って実行する方法です。

SSH2 関数

PHP のマニュアルページ

PHP のマニュアルの インストール手順 には、『この PECL 拡張モジュールの DLL は、現在存在しません。』とありますが、普通にあります。


ssh2

但し、使用する PHP の種類によってダウンロードするモジュールが変わってきます。



Non Thread Safe (NTS) か、Thread Safe (TS) かの違いは、phpinfo() で表示される以下の表示で確認して下さい


※ この状態ですと、Non Thread Safe (NTS)

ダウンロードした内容は、libssh2.dll と php_ssh2.dll ですが、libssh2.dll は、php ディレクトリにコピーして、php_ssh2.dll は、PHP のモジュールとして配置(通常 ext ディレクトリ)して、php.ini で記述します。
extension=php_ssh2.dll
<?php
$conn = ssh2_connect('サーバー名', 22 );
if (!$conn) {
	print "ssh2_connect: error";
	exit();
}

$auth = ssh2_auth_password($conn, 'アカウント', 'パスワード');
if (!$auth) {
	print "ssh2_auth_pubkey_file : error";
	exit();
}

$act = ssh2_scp_recv($conn, '/home/winofsql/www/student/lightbox/sample.json', './sample.json');
if (!$act) {
	print "ssh2_scp_recv : error";
	exit();
}

$act = ssh2_scp_send($conn, './136803326938078.jpeg', '/home/winofsql/www/student/lightbox/136803326938078.jpeg');
if (!$act) {
	print "ssh2_scp_send : error";
	exit();
}

?>
OK

参考になる海外サイト

Using SSH and SFTP with PHP
PuTTY Download Page

関連する WEB 情報

SSH について( さくらインターネット )



タグ:ssh PHP
posted by lightbox at 2013-11-08 23:24 | PHP + 通信 | このブログの読者になる | 更新情報をチェックする

2013年08月24日


PHP : メール送信(unix : パスワード不要)

sendmail は使用できません。sakura 等、自分で借りているサーバーで動くはずです。また、このような URL を用意しておけば、Android 等のメール送信用の API としてテストに使う事ができます。
さくらインターネット、サーバコントロールパネル ( 作成直後は、容量制限が 200M なので 2M 程度に変更しておきます ) ❷ Gmail の GUI( メールヘッダ等を確認するのに役立ちます ) ❸ メーセージソースの一部
To: =?ISO-2022-JP?B?GyRCMDhAaBsoQg==?= <??????????@gmail.com>
Subject: =?ISO-2022-JP?B?GyRCJWEhPCVrJE4lPyUkJUgbKEI=?=
 =?ISO-2022-JP?B?GyRCJWskSCRKJGokXiQ5GyhCKGxpZ2h0Ym94KQ==?=
From: =?ISO-2022-JP?B?GyRCO2QbKEI=?= <phpuser@??????????.sakura.ne.jp>
Mime-Version: 1.0
Content-Type: text/plain; charset=ISO-2022-JP
Content-Transfer-Encoding: 7bit

$BK\J8$r(B
$BAw?.$7$^$9(B
$B%+%J(B
$B%+%J(B

▼ ここからが本題です

PHP でメール処理をする場合、いろいろなキャラクタセットが入り組んで来るので注意が必要です。

ここではだいたいですが、このようになっています。

❶ 入力 HTML : EUC-JP
❷ PHP のソース : UTF-8
❸ PHP の内部エンコーディング : UTF-8
❹ メール内 : iso-2022-jp( 但しヘッダ内はBASE64変換 )

▼ mailtest.php
<?
header( "Content-Type: text/html; Charset=utf-8" );
header( "Expires: Wed, 31 May 2000 14:59:58 GMT" );

foreach( $_POST as $Key => $Value ) {
	$_POST[$Key] = str_replace("\\\\", "\\", $Value );
	$_POST[$Key] = str_replace("\\'", "'", $_POST[$Key] );
	$_POST[$Key] = str_replace("\\\"", "\"", $_POST[$Key] );
}

// ************************************************************************
// unix では、sendmail を使用します。
// 通常、この URL から信頼されているメールアドレス前提にしているので、
// セキュリティ情報は送る事ができません
// window 環境でもそれは同様なので、同一サーバーにメールサーバー
// を用意するか、COM+basp21でセキュリティ情報を使って送信する必要があります
// ************************************************************************

// mb_send_mail() は、e-mail をエンコードする際にこの設定を使用します
// ※ subject と body のみ
mb_language( "ja" );
mb_internal_encoding("utf-8");

// *********************************************************
// 使用するメールアドレス
// ※ $from_address は、この PHP があるサーバが
// ※ 管理しているメールサーバーのアドレスです
// ※ gmail に送ると、ヘッダーのソースを簡単に確認できます
// *********************************************************
$from_address = "phpuser@????????.sakura.ne.jp";
$to_address = "???????@gmail.com";

// *********************************************************
// 入力データが EUC-JP であると言う前提です
// ※ $subj はこの内部で設定しているので UTF-8 です。
// *********************************************************
$subj	= "メールのタイトルとなります(lightbox)";
$body	= mb_convert_encoding( $_POST['text'], mb_internal_encoding(), "EUC-JP" );
// *********************************************************
// 「半角カタカナ」を「全角カタカナ」に変換します
// *********************************************************
$body = mb_convert_kana($body,'K',mb_internal_encoding());


// *********************************************************
// 宛先と差出人は自分でエンコードする必要があります
// *********************************************************
$to	= mb_encode_mimeheader( mb_convert_encoding("宛先","iso-2022-jp", mb_internal_encoding()) ) . " <{$to_address}>";

// *********************************************************
// From: は追加ヘッダーとして設定しています
// *********************************************************
$from	= "From: " . mb_encode_mimeheader( mb_convert_encoding("私","iso-2022-jp", mb_internal_encoding()) ) . " <{$from_address}>";

$result = mb_send_mail($to, $subj, $body, $from );
if ( $result ) {
	$result = "成功";
}
else {
	$result = "失敗";
}

// ▼ この文字列は UTF-8 です
?>
メール送信が終了しました。<?= $result ?>


▼ 送信テスト用の HTML
<!doctype html>
<html lang="ja">
<head>
<title>sendmail</title>
<meta charset="euc-jp">
<style>
body {
	margin: 0px;
}
textarea {
	width:400px;
	height:200px;
}
</style>
</head>

<body>

<form method="post" action="mailtest.php">
<textarea name="text"></textarea>
<br>
<input type="submit" name="send" value="送信">
</form>

</body>
</html>



関連する記事 ( SQLの窓 )Windows PHP(Pear)で、Gmail(SSL/465)を使ってメールを送るPEAR の Mail パッケージによるメール送信IE 拡張メニューで取得したテキストをメールで送る


更新履歴
2009-05-06 : 初回投稿
2013-08-24 : WEB 経由の API として使う為に内容をチェック、整備




タグ:メール PHP
posted by lightbox at 2013-08-24 16:03 | PHP + 通信 | このブログの読者になる | 更新情報をチェックする

2010年06月11日


PHP の cURL でファイルアップロード

cURL を使うとWEBの通信部分の面倒な部分( ssl や ファイルアップロード ) を簡単に処理してくれます。ここで、test.php は、WEB サーバー上ですが、upload.php は、Windows のローカルPC から、コマンドプロンプトで php.exe upload.php で実行可能です

関連する記事

VBScript から PHP へファイルアップロード
PHP : cURL で FTP + SSL ダウンロード

test.php
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=Shift_JIS" />
</head>
<body>
<form 
	enctype="multipart/form-data"
	method="POST"
>
 
	アップロードするファイル : 
	<input name="target" type="file" style='width:400px'>
	<input type="submit" value="アップロード">
 
</form>
<pre>
<?php
if ( $_SERVER['REQUEST_METHOD'] == "POST" ) {
 
	$upload = realpath ( "./image" );
	$upload .= ( "\\" . $_FILES['target']['name'] );
	if ( move_uploaded_file(
		$_FILES['target']['tmp_name'], $upload ) ) {
		print "アップロードに成功しました<br>\n";
	}

	print_r( $_FILES );

}

?>
</pre>
</body>
</html>


upload.php
<?php
// ***************************************************
// ファイルのアップロード( cURL による直接アップロード )
// ***************************************************
header( "Content-Type: text/html; Charset=shift_jis" );
header( "pragma: no-cache" );
header( "Expires: Wed, 31 May 2000 14:59:58 GMT" );
header( "Cache-control: no-cache" );

// ***************************************************
// curl 処理
// ***************************************************
$curl = curl_init();
curl_setopt($curl, CURLOPT_CONNECTTIMEOUT, 30);
curl_setopt($curl, CURLOPT_HEADER, false);
curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);
// ▼ PHP 5.1.3 以降では、CURLOPT_BINARYTRANSFER は何の効果もありません。
curl_setopt($curl, CURLOPT_BINARYTRANSFER, true);
curl_setopt($curl, CURLOPT_URL, "http://localhost/web/upload/test.php");
curl_setopt($curl, CURLOPT_POST, true);

$data = array( 'target' => '@' . realpath("./lightbox_a.jpg") );
curl_setopt($curl, CURLOPT_POSTFIELDS, $data );

// ***************************************************
// 送信
// ***************************************************
curl_setopt($curl, CURLOPT_VERBOSE, true);	// デバッグ
$handle = fopen("./debug.txt", "w");
curl_setopt($curl, CURLOPT_STDERR, $handle);
$handle2 = fopen("./ret_header.txt", "w");
curl_setopt($curl, CURLOPT_WRITEHEADER, $handle2);
$result = curl_exec($curl);


// ***************************************************
// 結果
// ***************************************************
if($result === false) {
	$result = 'Curl error: ' . curl_error($curl);
}
curl_close($curl);
fclose($handle2);
fclose($handle);

print( $result . "\n" );

?>






タグ:Curl
posted by lightbox at 2010-06-11 17:03 | PHP + 通信 | このブログの読者になる | 更新情報をチェックする

2010年05月18日


PHP : OAuth用 rfc3986 の urlencode

PHP 5.3.0 より前のバージョンでは、rawurlencode はチルダ (~) もエンコードしていました。これは ≫ RFC 1738 で定められた方法です。
<?php

print str_replace(
	'%7E',
	'~',
	rawurlencode("a b 日本語")
)

?>

と言うか、php 5.2.x と 5.3.x で rawurlencode の動作が違うようです。上記は、5.2.x 用で、5.3.x では必要無いみたいです

関連する記事

VBScript : URLEncode( OAuth 用 rfc3986 )

PHP / JavaScript / ASP / PowerShell / python / Framework(バージョン別) : 処理別の urlencode の結果の違い



タグ:API twitter
posted by lightbox at 2010-05-18 08:44 | PHP + 通信 | このブログの読者になる | 更新情報をチェックする

PHP : http_build_query

$_POST の内容等をリンクで他のページへ投げたい時に
<?
// shift_jis
print http_build_query(array(a=>1,b=>2,c=>"日本語"))

?>
a=1&b=2&c=%93%FA%96%7B%8C%EA


posted by lightbox at 2010-05-18 08:31 | PHP + 通信 | このブログの読者になる | 更新情報をチェックする

2009年12月05日


PHP : コマンドプロンプトから実行するPHPを利用したFTPダウンロード

ブラウザでダウンロード
PHP を使った FTP ダウンロードのサンプルですが、パスワードの扱いが唯一気になります。
コマンドプロンプトで入力させると、エコーで表示されてしまうので、
最も簡単な方法でエコーを非表示にする方法を考えてみました。

VB.net で小さいプログラムを書きましたが、
何か他の処理に転用できるかもしれません。

<?
// 引数がある場合は、その引数をパスワードとする
if ( $argc == 2 ) {
	$pass = $argv[1];
}
// 引数が無い場合は入力させる
else {
	$pass = rtrim(fread( STDIN, 128 ));
}

$base_dir = "/lightbox.on.coocan.jp/homepage/download";
$file_name = "WinOfSql102.lzh";

$conn = ftp_connect("ftp.on.coocan.jp");
if (!$conn) {
	die('接続できません' . "\n");
}

$result = @ftp_login($conn, "lightbox.on.coocan.jp", $pass); 
if (!$result) {
	die('ログインできません' . "\n");
}

ftp_pasv($conn, true);

ftp_get($conn, $file_name, "$base_dir/$file_name", FTP_BINARY );

ftp_close($conn);

print "処理が終了しました\n";

?>

以下はバッチファイルの内容ですが、実際やってみると
パイプやリダイレクトをすると、そのアプリで色を変えても
反映されませんでした。それで、別々に実行しています。
@echo off

echo 以下にパスワードを入力して下さい & pass 0 0 & pass | php.exe ftp_download.php > message.txt & cls & pass 0 15 & type message.txt

また、cls を実行しておかないと、color 0F を実行すると見えてしまいます。
color コマンドは前景と背景を同じ色にできないのでわざわざ
そういう機能を持たせています( "pass 0 0" で何も見えなくなります )

なにか特別な方法で見えてしまう可能性もありますが、
ダイレクトに見せてしまうよりマシな一つの方法として試してみました
Module MyModule

' ********************************************************
' * クリップボードにあるファイル情報を標準出力へ
' ********************************************************
Sub Main()

	Dim argv As String()

	argv = System.Environment.GetCommandLineArgs()

	if argv.Length = 1 then
		Dim str As String = Console.ReadLine()
		Console.WriteLine( str )
	end if

	if argv.Length = 3 then
		Console.BackgroundColor = Integer.Parse(argv(1))
		Console.ForegroundColor = Integer.Parse(argv(2))
	end if

End Sub

End Module

vb.net のビルドをしたい場合は、以下を参考にして下さい
VB.net : ( vbc.exeで )自分でも簡単にビルドできる HTTP プロトコルを用いたダウンローダ





タグ:ftp PHP
posted by lightbox at 2009-12-05 09:24 | PHP + 通信 | このブログの読者になる | 更新情報をチェックする
Seesaa の各ページの表示について
Seesaa の 記事がたまに全く表示されない場合があります。その場合は、設定> 詳細設定> ブログ設定 で 最新の情報に更新の『実行ボタン』で記事やアーカイブが最新にビルドされます。

Seesaa のページで、アーカイブとタグページは要注意です。タグページはコンテンツが全く無い状態になりますし、アーカイブページも歯抜けページはコンテンツが存在しないのにページが表示されてしまいます。

また、カテゴリページもそういう意味では完全ではありません。『カテゴリID-番号』というフォーマットで表示されるページですが、実際存在するより大きな番号でも表示されてしまいます。

※ インデックスページのみ、実際の記事数を超えたページを指定しても最後のページが表示されるようです

対処としては、このようなヘルプ的な情報を固定でページの最後に表示するようにするといいでしょう。具体的には、メインの記事コンテンツの下に『自由形式』を追加し、アーカイブとカテゴリページでのみ表示するように設定し、コンテンツを用意するといいと思います。


※ エキスパートモードで表示しています

アーカイブとカテゴリページはこのように簡単に設定できますが、タグページは HTML 設定を直接変更して、以下の『タグページでのみ表示される内容』の記述方法で設定する必要があります

<% if:page_name eq 'archive' -%>
アーカイブページでのみ表示される内容
<% /if %>

<% if:page_name eq 'category' -%>
カテゴリページでのみ表示される内容
<% /if %>

<% if:page_name eq 'tag' -%>
タグページでのみ表示される内容
<% /if %>
この記述は、以下の場所で使用します
container 終わり

フリーフォントで簡単ロゴ作成
フリーフォントでボタン素材作成
フリーフォントで吹き出し画像作成
フリーフォントではんこ画像作成
ほぼ自由に利用できるフリーフォント
フリーフォントの書体見本とサンプル
画像を大きく見る為のウインドウを開くボタンの作成

CSS ドロップシャドウの参考デモ
BUTTONS (CSS でボタン)
イラストAC
ぱくたそ
写真素材 足成
フリーフォント一覧
utf8 文字ツール
右サイド 終わり
base 終わり