Sunday, December 07, 2008

yahoo messenger : change handle

メニュー Messnger> My Contact Details

Nicknameを変更する。

Thursday, October 16, 2008

curlによるSSL sample

$ch=curl_init();
$url = "https://hoge.coom/authentication_email.php";
curl_setopt ($ch,CURLOPT_URL, $url );
curl_setopt ($ch,CURLOPT_POST,1);
$post = "email=".$_POST['email'];
curl_setopt($ch,CURLOPT_POSTFIELDS,$post);
curl_setopt($ch,CURLOPT_SSL_VERIFYPEER,FALSE);
curl_setopt($ch,CURLOPT_SSL_VERIFYHOST,FALSE);
// curl_setopt ($ch,CURLOPT_RETURNTRANSFER, FALSE);
curl_setopt ($ch,CURLOPT_RETURNTRANSFER, 1);

$ret = curl_exec($ch);

if (empty($ret)) {
// some kind of an error happened
die(curl_error($ch));
curl_close($ch); // close cURL handler
} else {
echo $ret;
// $info = curl_getinfo($ch);
curl_close($ch); // close cURL handler
}

Wednesday, October 08, 2008

PHP コマンドライン

php -i phpinfoと同じ
php -l シンタックスエラーチェック perl -wcのPHP版 使用例 php -l test.php

Sunday, September 21, 2008

tar.bz2の解凍

tar jxvf aaa.tar.bz2

tar xvfz tar xvfz qmail-1.03.tar.gz

Thursday, September 11, 2008

apache1.3とPHP4とPHP5

apacheとPHP4で運用していてphp5を試したいときにの方のための記述
php5(cgi)で行う。
インストールは例--with-apxs2や--with-apxsをつけないでインストールする。

その後以下のようにシンボリックリンクを張ります。

apache/cgi-bin/php5 -> /bin/php-cgi 

php-cgiは コマンドラインから実行するとヘッダ (text/html)を出力する


apacheの設定ファイルを以下のようにします。
<Directory "/**/apache/cgi-bin">
Options +ExecCGI +FollowSymLinks
AllowOverride All
Order allow,deny
Allow from all
</Directory>

<Directory "/home/tomo/htdocs">
AddHandler php5-script .php
Action php5-script /cgi-bin/php5
Options +ExecCGI +FollowSymLinks
AllowOverride All
Order allow,deny
Allow from all
</Directory>

指定の場合
/home/tomo/htdocsの下のphpはphp5のcgiとして実行されます。

Wednesday, September 10, 2008

mod_perl

apache2とmod_perl

perl Makefile.PL MP_APXS=/usr/bin/apxs2
make
make install

httpd.conf

AddHandler cgi-script .cgi .pl
LoadModule perl_module lib/httpd/modules/mod_perl.so

<Files *.pl>
SetHandler perl-script
# PerlHandler ModPerl::PerlRun
PerlResponseHandler ModPerl::Registry

PerlSendHeader On
Options +ExecCGI
</Files>

確認の方法
#!/usr/bin/perl
print "Content-type: text/plain\n\n";
foreach $key (sort keys %ENV) {
print "$key = $ENV{$key}\n";
}
で $ENV{'MOD_PERL'}があればOK

Tuesday, September 09, 2008

L 99 99 99 99 99 99 99 99

liloが壊れている


CDまたはDVDブートでlinuxを立ち上げて lilo.confを修正する。

Monday, September 08, 2008

USB HD(ハードディスク)の接続 for Linux

USBをPCに接続後に以下のコマンドを入力し、USBが正しく認識されているか確認する。

cat /proc/bus/usb/devices
cat /proc/scsi/scsi
(HDはscsi 扱い)

問題ない場合dmesgコマンドを実行し、認識されている情報を取得

SCSI device sda: 20028960 512-byte hdwr sectors (10255 MB)
sda: Write Protect is off
sda: Mode Sense: 23 00 00 00
sda: assuming drive cache: write through
sda: sda1 sda2

sda1とsda2で認識されている。
元々HDはLinuxで使用していたものなので
sda1はswap パーティンション

マウントの場所を作成
mkdir /mnt/usb (例)
mount /dev/sda2 /mnt/usb

アンマウントは以下になります。
umount /mnt/usb

PHP キャッシュされないため

header("Content-type: text/html; charset=utf-8");
header("Expires: -1");
header("Last-Modified: ". gmdate("D, d M Y H:i:s"). " GMT");
header("Cache-Control: no-cache, must-revalidate");
header("Pragma: no-cache");

Smarty 設定確認用PHP

単純にSmartyをインストールしたときに動作するかの確認

phpinfo();
で確認してから
---

<?php
require_once( 'MySmarty.class.php');
$objSmarty =& new MySmarty;

// $objSmarty->assign('name','Smarty man');
$objSmarty->display('hello.html');
?>

PHP Cookieの確認サンプル

<?php

print_r($_COOKIE);

?>

PHP mysqli_connectのサンプル

if (!($cn = mysqli_connect("localhost", "hoge", "hoge"))) {
die;
}

if (!(mysqli_select_db($cn,"test"))) {
die;
}
$sql = "select * from address";
if (!($rs = mysqli_query($cn,$sql))) {
die;
}

$i=0;
while ($item = mysqli_fetch_array($rs)) {
print "${item['id']} ";
print "${item['name']} ";
print "
";
$data[$i]['name']= $item['name'];
$data[$i]['tel']= $item['tel'];
$i++;
}

mysqli_close($cn);

Thursday, September 04, 2008

PHP 日本語送信

よくあるパターンなのですが、PEARとか使えない環境のため

<?php
mb_internal_encoding( "UTF-8");
mb_language("Japanese");

header("Content-Type: text/html; charset=UTF-8");

// UTF-8

if (my_email("atesaki@example.com")){
print "メールを送信しました。";

}else{
print "メールの送信に失敗。";
}

function my_email ($to) {
$from = mb_encode_mimeheader("送信者") . "<from@example.net>";
$sbj = "タイトル";
$msg = "本文です。";
$header = "From: {$from}";
return mb_send_mail($to , $sbj , $msg , $header);
}

?>

Tuesday, August 26, 2008

外部キーの取得 MYSQL

select * from information_schema.table_constraints where constraint_type like 'for%'

Wednesday, August 20, 2008

mysql install

インストール
cd /home/**/app-src/mysql
wget mysql-**.tar.gz
./configure --prefix=/home/**/app/mysql
make; make install

DBの初期化
./scripts/mysql_install_db

サーバを起動
/home/**/app/mysql/bin/mysqld_safe &

パスワードを設定する
/home/***/app/mysql/bin/mysqladmin -u root password 'new-password'
パスワードはnew-passwordになる。

ユーザの追加
mysql -u root mysql

GRANT ALL PRIVILEGES ON *.* TO hogehoge@localhost IDENTIFIED BY 'password' WITH GRANT OPTION;
パスワードはpasswordとなる。


GRANT ALL PRIVILEGES ON *.* TO root@localhost IDENTIFIED BY 'hogehoge' WITH GRANT OPTION;




サーバーの停止
./mysqladmin -u root -p*** shutdown

Create table の表示
SHOW CREATE TABLE ****;

エラーはログを見ること。
次のエラーの場合、
Table 'mysql.host' doesn't exist

mysql_install_dbをすると直るときもある。

http://kajuhome.com/mysql.shtml#n07

Monday, August 04, 2008

mysql 場所

インストールの方法によって異なりますが。。。

/usr/local/mysql/var

ls -la
drwx------ 17 mysql mysql 4096 2000-00-00 00:00 var/

Sunday, August 03, 2008

phpPgAdmin でログインできない

cd phppgadmin/conf/
vim config.inc.php

$conf['extra_login_security'] = true;
以下のように変えます。
$conf['extra_login_security'] = false;

Wednesday, July 16, 2008

Javascript とHTMLの分離。

自分ひとりでWEBページをつくる場合はそれほど気にならないが、
デザイナーさんと同時につくるとき、HTMLとjavascriptの分離は必要かもしれない。
デザイナーさんのjavascriptに対する拒否反応はプログラマーには分からない。
というか分からなかった。

ちょっと調べてみると以下のサイトが見つかったので、参考にリンクを貼る。

イベントハンドラをHTMLから分離する

http://allabout.co.jp/internet/javascript/subject/msubsub_series_javascript06.htm

Tuesday, July 15, 2008

Flash CS3 超初心者入門

Flash CS3 超初心者入門

新規>Flashファイル AS3.0を選択。

ボタンをドキュメントに配置する。
ボタンは「ウィンドウ」>「コンポーネント」>User Interfaceからドラックする
ボタンをクリックし、プロパティで「インスタンス名」に「btn1」とする

ウィンドウ>アクションで「アクションウィンドウ」を表示。
レイヤーをクリックし、アクション フレームに以下のように書く。


function hogehoge(e){
trace("hogehoge");

};

btn1.addEventListener(MouseEvent.CLICK,hogehoge);

デバッグを選択すると出力に traceの内容が表示される。

ファイル>パブリッシュプレビューを選択で確認もできます。

Wednesday, July 09, 2008

Jquery HTML フォームの連携のサンプル

inputタグとFrom IDのサンプルです。

<head>
<script type="text/javascript" src="/js/jquery.js"></script>

<SCRIPT LANGUAGE="javascript">
$(function ()
{
$('#p').submit(function ()
{

if(!$('input[@name=email]').val()) {
alert("メールアドレスを入力してください");
return false;
}else{
return true;
}
});

});
</SCRIPT>

</head>
<body>
<form id="p" method=post action=hoge.php>
<input name="email" type="text" />
<input name="submit" type="image" src="images/btn.gif" alt="送信する" >
</form>

Saturday, June 14, 2008

MVC コントローラー URLによる動的にモジュールを呼ぶ

----- test.php
<?php

/*
e.g
test.php/c=user_proile/m=register/

*/

$path_info = explode('/', $_SERVER['PATH_INFO']);
while(list($cnt,$path) = each($path_info)) {
if ($path == "") continue;
list($key,$value) = explode('=', $path);
if ($key =="c") {
$MyClass = $value;
continue;
}
if ($key =="m") {
$MyMethod = $value;
continue;
}

$_GET[$key] = $value;
}

// overloading is also ok, if PHP5.
if ($MyClass != "" && is_file($MyClass.".php")) {
include_once($MyClass.".php");
if (class_exists($MyClass)) {
$MyModel = new $MyClass;
if (method_exists($MyModel,"dispatch")) {
$MyModel->dispatch($MyMethod);
}
}
}


?>
-----user_proile.php

<?php
class user_proile
{
function dispatch($action)
{
echo $action;

}


}
?>

refer to:
2008/03/php-mvc-controller.html

2005/01/pathinfo.html

Thursday, June 12, 2008

PHP4 でのRSS リーダー sample

http://keithdevens.com/software/phpxml
からPHP XML Libraryをとってくる。


<?php // Load and parse the XML document

$url = 'http://hogehoge/blog/?feed=rss2';

$xml_data1 = file_get_contents($url) or die();

require_once('xml.php');
$xml_array = XML_unserialize($xml_data1);
$items = $xml_array['rss']['channel']['item'];
unset ($xml_array);
unset ($xml_data1);

foreach ($items as $item) {
echo "<h3><a href='" . $item['link'] . "'>" . $item['title'] . "</a></h3>";
echo "<p>" . mb_strimwidth($item['description'], 0, 60, "...",'utf8') . "</p>";
break;

}
unset ($items);


?>

php ファイル名の一覧の取得

<?php

$regex = "([^\/]+).mp3$";
$dir =".";
if ($handle = opendir($dir)) {
while (false !== ($file = readdir($handle))) {
if ( preg_match ( "/".$regex."/", $file, $matches) ) {
echo $file;
$files[] = $file;
// $matches[1]で名前だけとるのもあり。
}
}
closedir($handle);
}

?>

Tuesday, June 10, 2008

rss reader by PHP5 (sample)

<?php

$feed = 'http://test.com/?feed=rss2';
$rss = simplexml_load_file($feed);
$title = $rss->channel->title;
?>
<html>
<head>
<title><?php echo $title; ?></title>
</head>
<body>

<h1><?php echo $title; ?></h1>

<?php
foreach ($rss->channel->item as $item) {
echo "<h3><a href='" . $item->link . "'>" . $item->title . "</a></h3>";
$pdate = $item->pubDate;
echo date("Y/m/d G:H:i",strtotime($pdate));
echo "<p>" . $item->description . "</p>";
echo "<p>" . $item->category . "</p>";
}
?>

</body>
</html>

Wednesday, June 04, 2008

WordPressで独自ページをつくるサンプル

<?php

define('WP_USE_THEMES', false);
require('wp-blog-header.php'); // 共通関数を使うため
get_header();// テンプレートを仕様

$sql = "SELECT category_count FROM " .$wpdb->categories . " WHERE cat_ID=1" ;
echo $wpdb->get_var($sql);
get_footer(); // テンプレートを仕様

?>

-------------------------------
<?php
require('wp-blog-header.php'); // 共通関数を使うため
$option = 'cat=3&showposts=100&year=2008&order=ASC';

?>
<?php query_posts($option); ?>
<?php if(have_posts()):while(have_posts()):the_post(); ?>
<p><?php the_time('Y.m.d'); ?></p>
<p><a href="detail.php?id=<?php the_ID(); ?>"><?php echo $post->post_title ; ?></a>
</p>
<p><?php the_content(); ?></p>

<?php endwhile;endif; ?>

---------

カテゴリ指定の年ごとのリンクの作成

$category_id = 3;
$sort =" ASC";

$arcresults = $wpdb->get_results("SELECT DISTINCT YEAR(post_date) AS year, count(ID) as posts
FROM $wpdb->posts, $wpdb->term_relationships
WHERE
$wpdb->posts.ID = $wpdb->term_relationships.object_id
AND $wpdb->posts.post_type = 'post'
AND $wpdb->posts.post_status = 'publish'
AND $wpdb->term_relationships.term_taxonomy_id = '$category_id'
GROUP BY YEAR(post_date) ORDER BY post_date " . $sort);

foreach ($arcresults as $arcresult) {
echo "<li><a href=\"/?year=".$arcresult->year."\">".$arcresult->year."年</a></li>";
}


----
bloggerの投稿するときの文字の確認を入力、読めない

Tuesday, June 03, 2008

PHP memcache のインストール

簡単にインストールできると思ったら失敗したのでここに記す。

pecl download memcache

pecl install memcache-2.2.3.tgz << 落としたものにする

インストールに設定したら、php.iniの編集

extension=memcache.so

動かない場合は インストール成功時に表示されるパスを書けばOK
extension="/usr/local/lib/php/extensions/no-debug-non-zts-20060613/memcache.so"

最後にapacheの再起動
再起動をしないとphpは反映されません。

Thursday, March 27, 2008

PHP MVC controllerの勉強

class base {

function __construct() {
}
function dispatch($action){
try{
$this->$action();
}catch( Exception $e ){
$this->errorAction($e->getMessage());
}
}
function errorAction($str=null){
echo "overridden";
}
}

class Front extends Base {

function __construct() {
}

function page() {
throw new Exception( 'Template error.' );
echo "page";
}

function errorAction($str=null){
echo "Front:".$str;
}
}

$f = new Front;
$f->dispatch("page");

Wednesday, January 16, 2008

mod_rewrite 特定のURLを対象外

<Directory "/***">
RewriteEngine On
RewriteBase /

RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteCond %{REQUEST_FILENAME} !\.(cgi|css|gif|jpe?g|png)$


RewriteRule ^(.+)/bookmark/movie/list/([0-9]+)/?$ hoge2.php?page=$1&id=$2&%{QUERY_STRING} [L]
RewriteRule ^(.+)/movie/list/([0-9]+)/?$ hoge.php?page=$1&page2=$2&%{QUERY_STRING} [L]



</Directory>

Tuesday, January 15, 2008

直リンクの禁止 バーチャルドメインの場合

<VirtualHost 192.168.*.*>
ServerName example.com
DocumentRoot /home/example/htdocs
ServerAdmin webmaster@www.hoge.co.jp
ErrorLog logs/error_log
TransferLog logs/access_log

#<Files *.gif>

<Files ~ "\.(tbz|tgz|bz2|gz|tar|lzh|zip|mag|png|jpeg|jpg|gif)$">

SetEnvIf referer "^http://example\.com" RefOk
Order Deny,Allow
Deny from all
Allow from env=RefOk
</Files>

</VirtualHost>

Monday, January 07, 2008

年齢 MYSQL PHP

select (YEAR(CURDATE())-YEAR(birth))- (RIGHT(CURDATE(),5) <RIGHT(birth,5)) AS age from hoge

----

PHPの場合

<?php
$birthday = '1990-01-12';
$lapse = getdate(mktime()-mktime(0,0,0,substr($birthday,5,2),
substr($birthday,8,2),substr($birthday,0,4)));
$age = $lapse['year']-1990;
echo $age;
?>
~

Thursday, January 03, 2008

javascript 日付チェック

if(!chkDate(document.form.year.value,document.form.month.value,document.form.day.value)) {
alert("日付を正しく入力してください。");
return false;
}


function chkDate(y,m,d){
var date1 = new Date(y,m-1,d);
if(date1.getFullYear() == y && date1.getMonth() == m-1 && date1.getDate() == d){
return true;
}
return false;
}