Wikipokpok:ブログ

提供: wikipokpok
2013年1月14日 (月) 00:13時点におけるShudo (トーク | 投稿記録)による版

移動先: 案内検索

目次

 [非表示

Mediawikiについて

FancyCaptchaによるスパム対策

Image ninnsyou.png

アカウント作成時や外部リンクを挿入する際、画像の文字認証を入力させる。

  1. Python Imaging Library (PIL) をインストールする。
$ sudo apt-get install python-imaging
  1. LocalSettings.phpに次の行を追加する。
require_once("$IP/extensions/ConfirmEdit/ConfirmEdit.php");
require_once("$IP/extensions/ConfirmEdit/FancyCaptcha.php");
$wgCaptchaClass = 'FancyCaptcha';
$wgCaptchaDirectory = "$IP/extensions/captcha";
$wgCaptchaDirectoryLevels = 0; // Set this to a value greater than zero to break the images into subdirectories
$wgCaptchaSecret = "FOO"; // same value you used in --key option in captcha.py
  1. それから次のコマンドを実行する。
$ cd /foo/bar/extensions/ConfirmEdit/
$ python captcha.py --font=/usr/share/fonts/truetype/ttf-dejavu/DejaVuSans.ttf --wordlist=/usr/share/dict/words --key=FOO --output=/foo/bar/extensions/captcha --count=100

参考ページExtension:ConfirmEdit

フォントサイズの変更

$ sudo vi /foo/bar/skins/vector/screen.css

body {
 	height: 100%;
	margin: 0;
	padding: 0;
	font-family: sans-serif;
	font-size: 1em; ←ここを1.04emにした。
}

Linuxコマンド

/etc/apt/sources.listの書き換え

sudo sed -i".bak" 's/http:\/\/jp.archive.ubuntu.com\/ubuntu/http:\/\/ftp.jaist.ac.jp\/pub\/Linux\/ubuntu/' sources.list

ssh

Bパソコンでid_rsa(秘密鍵)とid_rsa.pub(公開鍵)をつくる。passphraseを入れずにEnterを押すとパスワードなし接続ができる鍵ができる。

shudo@B:~$ ssh-keygen -t rsa

Bパソコンで作ったid_rsa.pub(公開鍵)をAパソコンにアップロードする。

shudo@B:~$ scp .ssh/id_rsa.pub AパソコンのIPアドレス:~/

Aパソコンにアップロードしたid_rsa.pub(公開鍵)をAパソコンの.sshのauthorized_keysに書き込む。

shudo@A:~$ cat id_rsa.pub >> .ssh/authorized_keys

これでBパソコンからAパソコンにsshパスワードなし接続ができる。Bパソコンのid_rsa(秘密鍵)をCパソコンにコピーすればCパソコンからもAパソコンにsshパスワードなし接続ができる。

rsync

参考サイト"B"-con

その他

文字コード変換 -w はUTF-8

nkf -w --overwrite example.csv

リンク

ln -s /リンク元/ /リンク先/

Ubuntuについて

Ubuntu11.04

VirtualBox

USB接続のプリンタを使えるようにする。 vboxusersグループ、lpグループに自分を追加する。

Screenshot-コントロール・センター.png Screenshot-ユーザの設定.png Screenshot-グループの設定.png Screenshot-'vboxusers' グループのプロパティ.png Screenshot-グループの設定-1.png Screenshot-'lp' グループのプロパティ.png

Thinkpadのトラックポイントスクロールを有効にする。

参考サイトUbuntu日本語フォーラム/Thinkpad TrackPoint Scrolling in Ubuntu Lucid/10.04

ファイルを新規作成する。
/usr/lib/X11/xorg.conf.d/20-thinkpad.conf
内容は以下のとおり。
Section "InputClass"
   Identifier "Trackpoint Wheel Emulation"
   MatchProduct "TrackPoint"
   MatchDevicePath "/dev/input/event*"
   Driver "evdev"
   Option "EmulateWheel" "true"
   Option "EmulateWheelButton" "2"
   Option "Emulate3Buttons" "false"
   Option "XAxisMapping" "6 7"
   Option "YAxisMapping" "4 5"
EndSection
再起動。

10.10以降ならgpointing-device-settingsをインストールすれば楽だ。参考サイトThinkpad TrackPoint Scrolling in Ubuntu Maverick/10.10

途中からトラックポイントスクロールが利かなくなったので/etc/X11/xorg.confを新規作成し上記の設定を書き加えた。 参考サイトUbuntuJapaneseWiki

PHP

phpMyAdmin

「リンクテーブルを処理するための追加機能が無効になっています。理由についてはこちらをご覧ください」解消

管理用テーブル(phpmyadmin)の作成

zcat /usr/share/doc/phpmyadmin/examples/create_tables.sql.gz > /tmp/create_tables.sql
mysql -u [mysql管理者ID] -p < /tmp/create_tables.sql
rm /tmp/create_tables.sql

/etc/phpmyadmin/config-db.php 編集

$dbname=”; を $dbname=’phpmyadmin’; に変更

/etc/phpmyadmin/config.inc.php 編集

$cfg['Servers'][$i]['designer_coords'] = ‘pma_designer_coords’; の下に
$cfg['Servers'][$i]['tracking'] = ‘pma_tracking’; を追記

参考サイト

未定義変数とエラー

Notice: Undefined variable: 未定義変数とエラーが返るときは『php.ini』の『error_reporting = E_ALL & ~E_NOTICE』を有効にして、他の『error_reporting 』を無効にする。

Apache

バーチャルホスト設定

参考サイトUbuntu Tips

LVMについて

まずVG (ボリュームグループ) の確認。

shudo@home-server:~$ sudo vgscan

PV (物理ボリューム) の作成。

shudo@home-server:~$ sudo pvcreate /dev/sda1

PVをVGに追加。

shudo@home-server:~$ sudo vgextend home-server /dev/sda1
 Volume group "home-server" successfully extended

LV(論理ボリューム)をVGから2GB切り出す。

shudo@home-server:~$ sudo lvcreate -nhome -L2g home-server
 Logical volume "home" created

LVの削除

shudo@home-server:/$ sudo umount /home/
shudo@home-server:/$ sudo lvremove /dev/home-server/home
Do you really want to remove active logical volume "home"? [y/n]: y
 Logical volume "home" successfully removed
shudo@home-server:~$ sudo lvdisplay /dev/home-server/home
 --- Logical volume ---
 LV Name                /dev/home-server/home
 VG Name                home-server
 LV UUID                6o5lfm-do8L-ZV8I-LOaJ-FEVU-P40o-Cpgxfv
 LV Write Access        read/write
 LV Status              available
 # open                 0
 LV Size                2.00 GB
 Current LE             512
 Segments               1
 Allocation             inherit
 Read ahead sectors     auto
 - currently set to     256
 Block device           252:2

切り出したLGをフォーマットする。

shudo@home-server:~$ sudo mkfs.ext4 -j /dev/home-server/home

空の/homeにマウントする。

shudo@home-server:~$ sudo mount /dev/home-server/home /home
shudo@home-server:~$ df -h
ファイルシステム            サイズ  使用  残り 使用% マウント位置
/dev/mapper/home--server-root
                      71G  1.6G   66G   3% /
udev                  2.0G  220K  2.0G   1% /dev
none                  2.0G     0  2.0G   0% /dev/shm
none                  2.0G  296K  2.0G   1% /var/run
none                  2.0G     0  2.0G   0% /var/lock
none                  2.0G     0  2.0G   0% /lib/init/rw
/dev/sdb5             228M   29M  188M  14% /boot
/dev/mapper/home--server-home
                     2.0G   67M  1.9G   4% /home

2GBの/homeに200GB足す。

shudo@home-server:~$ sudo umount /home/
shudo@home-server:~$ sudo lvextend -L+200g /dev/home-server/home
 Extending logical volume home to 202.00 GB
 Logical volume home successfully resized
shudo@home-server:~$ sudo mount /dev/home-server/home /home

202GBになった。

shudo@home-server:~$ sudo lvdisplay /dev/home-server/home
 --- Logical volume ---
 LV Name                /dev/home-server/home
 VG Name                home-server
 LV UUID                6o5lfm-do8L-ZV8I-LOaJ-FEVU-P40o-Cpgxfv
 LV Write Access        read/write
 LV Status              available
 # open                 1
 LV Size                202.00 GB
 Current LE             51712
 Segments               1
 Allocation             inherit
 Read ahead sectors     auto
 - currently set to     256
 Block device           252:2

自動マウントにする。

shudo@home-server:/$ sudo vi /etc/fstab
/dev/mapper/home--server-home /home               ext4    errors=remount-ro 0       1

寺院管理ソフト

CSVファイルからインポート

ファイルを移動する

shudo@shudo:~$ sudo cp meibo.csv /var/lib/mysql/tera/

インポート

mysql> LOAD DATA INFILE "meibo.csv" INTO TABLE kojins FIELDS TERMINATED BY ';' ENCLOSED BY '"' LINES TERMINATED BY '\n';

ZendFramework

apache2 php5 mysql phpMyAdmin SQLite zend-framework インストール

apt-get install apache2
apt-get install php5 libapache2-mod-php5
apt-get install mysql-server
apt-get install phpMyAdmin
apt-get install php5-sqlite
apt-get install zend-framework

mod_rewriteを有効にする

shudo@shudo:~$ sudo a2enmod rewrite
Enabling module rewrite.
Run '/etc/init.d/apache2 restart' to activate new configuration!
shudo@shudo:~$ sudo /etc/init.d/apache2 restart

エラー表示(する)

phpSettings.display_startup_errors = 1
phpSettings.display_errors = 1

PostgreSQL One-Clickインストーラというのもある

参考ページ[1]

Apache Web ServerとPHPはOne-Clickインストーラでインストールする。

インストーラーの起動の仕方。ファイル名を指定するだけ。

root@shudo-laptop:/home/shudo# ./postgresql-8.4.2-1-linux.bin 

mediaWikiもインストールできる。最後にLocalSettings.phpを移動する。

root@shudo-laptop:/home/shudo# mv /opt/PostgreSQL/EnterpriseDB-ApachePhp/apache/www/mediaWiki/config/LocalSettings.php /opt/PostgreSQL/EnterpriseDB-ApachePhp/apache/www/mediaWiki

Zend FrameworkはPEARと同じディレクトリにインストールした。include_pathも指定する。

/opt/PostgreSQL/EnterpriseDB-ApachePhp/php/lib/php

Zend FrameworkのクラスファイルがあるディレクトリZendFramework-1.9.7/library/Zendにシンボリックをとおす。

root@shudo-laptop:/home/shudo# cd /opt/PostgreSQL/EnterpriseDB-ApachePhp/php/lib/php
root@shudo-laptop:/home/shudo# ln -s ZendFramework-1.9.7/library/Zend

コマンドラインツール

root@shudo-laptop:/home/shudo# cd /usr/bin/
root@shudo-laptop:/home/shudo# ln -s /opt/PostgreSQL/EnterpriseDB-ApachePhp/php/lib/php/ZendFramework-1.9.7/bin/zf.sh
root@shudo-laptop:/home/shudo# zf.sh show versionZend
Framework Version: 1.9.7
shudo@shudo-laptop:~$ vi ~/.profile
alias zf=/opt/PostgreSQL/EnterpriseDB-ApachePhp/php/lib/php/ZendFramework-1.9.7/bin/zf.sh

/wwwの所有者を変更

shudo@shudo-laptop:/opt/PostgreSQL/EnterpriseDB-ApachePhp/apache$ chown -R shudo:shudo www

チュートリアル

参考ページ

プロジェクトの作成

shudo@shudo-laptop:/opt/PostgreSQL/EnterpriseDB-ApachePhp/apache/www$ zf.sh create project tera

2011/2/1

shudo@www-server:/var/lib/mediawiki$ zf create project a60

ライブラリにシンボリックをとおす

shudo@shudo-laptop:/opt/PostgreSQL/EnterpriseDB-ApachePhp/apache/www$ cd tera/library/
shudo@shudo-laptop:/opt/PostgreSQL/EnterpriseDB-ApachePhp/apache/www/tera/library$ ln -s /opt/PostgreSQL/EnterpriseDB-ApachePhp/php/lib/php/Zend

2011/2/1

shudo@www-server:/var/lib/mediawiki$ cd ./a60/library/
shudo@www-server:/var/lib/mediawiki/a60/library$ ln -s /usr/share/php/libzend-framework-php/Zend/

test

http://localhost/tera/public/

postgresのテーブルをmyslのテーブルに移す

idはコピーしない

a60=# \COPY a60_bbs_tab (name, text, date) TO a60bbscopy.txt

文字コードの調整

shudo@red:~$ nkf -w a60bbscopy.txt > a60bbscopyutf8.txt

ファイル名とテーブル名を合わせる

shudo@www-server:~$ mysqlimport -u shudo -p -c email,comment,created a60 guestbook.txt

Zend_Validateのメッセージを日本語にする

参考サイト

ハードディスクのまるごとコピーについて

コピー元のHDDより容量の大きいHDDを用意し、コピー元HDDと同じようにパーティションを切る。余った部分は未設定のままにしておく。手動でパーティションを切るのが煩わしいときは、とりあえず dd する。このとき bs を大きくして早々にコピーを済ませる。30G が bs=4096 で30分ぐらいだったと思う。コピーはできるが起動はしない。

dd if=/dev/sdb of=/dev/sdc bs=4096 conv=noerror,sync

次に、コピー先のHDDをアンマウントして一つずつボリュームをフォーマットする。それからボリューム毎にコピーする。

dd if=/dev/sdb1 of=/dev/sdc1 bs=2048 conv=noerror,sync
dd if=/dev/sdb5 of=/dev/sdc5 bs=2048 conv=noerror,sync
dd if=/dev/sdb6 of=/dev/sdc6 bs=2048 conv=noerror,sync
dd if=/dev/sdb7 of=/dev/sdc7 bs=2048 conv=noerror,sync
....

これで起動した。bsの値はいくつが適当かわからないが 4096 では不安なので 2048 にした。

NICの認識について

ネットに繋がらない。ifconfigでeth0がない。

dmesg | grep eth0 すると eth0 to eth4 のようなメッセージだったと思う。
/var/log/messages を見ると udev: renamed network interface eth0 to eth4 とあった。

そこで

/etc/udev/rules.d/70-persistent-net.rules

を開いて

eth0 をコメントアウトし、eth4 を eth0 に書き換えて再起動。

これで繋がった。

清少納言 枕草子について

966年?~1025年?平安時代の女流作家 清原諾子(なぎこ)?

「清少納言」は女房名で、「清」は清原の姓から、「少納言」は親族の役職名から採ったとされている。実名は不明、「諾子(なぎこ)」という説(『枕草子抄』)もあるが信ずるに足りない。

左大臣⇒右大臣⇒内大臣⇒大納言⇒中納言⇒参議⇒左大弁⇒右大弁⇒少納言

天元4年(981年)15歳の頃、橘則光と結婚し、翌年一子則長(982年 - 1034年)を生むも、武骨な夫と反りが合わず、やがて離婚した。

当時の結婚は、一夫多妻制で、通い婚であったために、主人がこなくなれば、それで離婚ということになり、下級に近い中級貴族の娘たちの結婚は、現在のように一生涯をかけての結婚生活という意識はあまりなかった。10年を過ぎたころに則光がこなくなり、それで離婚ということになった。

正暦4年(993年)27歳冬頃から、中宮定子(17歳)に仕えた。定子は正暦元年(990年)1月25日、数え14歳の春に、3歳年下の一条天皇に入内した。

博学で才気煥発な彼女は、主君定子の恩寵を被ったばかりでなく、公卿や殿上人との贈答や機知を賭けた応酬をうまく交わし、宮廷社会に令名を残した。

  • く‐ぎょう【公卿】公(こう)と卿(けい)の総称。公は太政大臣・左大臣・右大臣、卿は大納言・中納言・参議および三位以上の朝官をいう。
  • れい‐めい【令名】よい評判。名声。
  • 【草子】 物語・日記・歌書など、和文で記された書物の総称。


引用[2][3]

PostgreSQLについて

バックアップと復元

pg_dumpallのファイルから特定のテーブルのみをリストアする

  1. hogeテーブルのデータの一部を誤って消してしまったので、crondでpg_dumpallしているファイルから復元する。
  2. pg_dumpallで出力されたファイルをエディタで開き、復元したいテーブルのデータの部分だけをコピーして新しいhogedata.txtテキストファイルをつくる。
  3. hogeテーブルのデータをすべて消して、\copyでhogedata.txtのデータを戻す。
\COPY hoge_tab (id, name, zip, addr, phone) FROM /home/hogedata.txt


税務について

源泉徴収事務

従たる給与を支払う場合は乙欄の税額を適用する。

年末調整

控除対象配偶者と配偶者特別控除

(平成20年度)給与所得のみの場合、収入金額が103万円未満の場合は控除対象配偶者。収入金額が103万以上141万未満の場合は配偶者特別控除となる。

103万円未満と104万円の控除額は38万円で同じなので、どうしてか税務署に聞いてみた。すると所得税がかかるというところで違いがでるとのことだった。

Zend Frameworkについて

Zend_Db_Tableでのjoin

setIntegrityCheck(false)を書かないとエラーになるので注意。

$table = new Bugs();
$select = $table->select()->setIntegrityCheck(false);
$select->where('bug_status = ?', 'NEW')
      ->join('accounts',
             'accounts.account_name = bugs.reported_by',
             'account_name')
      ->where('accounts.account_name = ?', 'Bob');
$rows = $table->fetchAll($select);

Zend_Paginator

Zend_Paginatorの使い方を教えてください。リファレンスガイドを見ましたが分かりません。検索をかけても情報がありません。クイックスタートに組み込みたいと思っています。どなたかよろしくお願いします。--住職 2009年2月3日 (火) 18:16 (JST)

5つ表示してページを移動します。
右図のようにできました。参考にしたページは次の三つです。[4][5][6]--住職 2009年2月4日 (水) 11:50 (JST)
  • GuestbookController.php
    public function indexAction()
   {
       $model = $this->_getModel();
       //$this->view->entries = $model->fetchEntries();
       $entries = $model->fetchEntries();
       $paginator = Zend_Paginator::factory($entries);
       //1ページに表示するエントリ数
       $paginator->setItemCountPerPage(5);
       $paginator->setCurrentPageNumber($this->_request->getParam('page'));
       $this->view->paginator = $paginator;
   }
  • /views/scripts/guestbook/index.php
   <? //foreach ($this->entries as $entry): ?>
   <? foreach ($this->paginator as $item): ?>
   <?= $this->escape($item['id']) ?>[<?= $this->escape($item['name']) ?>]
   <?= $this->escape($item['comment']) ?>
   <?= $this->escape($item['created']) ?>
   <? endforeach ?>
   //pagination_control.phtmlは/views/scripts/内につくる。
   <?= $this->paginationControl($this->paginator, 'Sliding', 'pagination_control.phtml'); ?>
  • /views/scripts/pagination_control.phtml
<?php if ($this->pageCount): ?>  
<?php if (isset($this->previous)): ?> 
 <a href="<?= $this->url(array('page' => $this->previous)); ?>">前へ</a>
<?php else: ?> 
 前へ
<?php endif; ?> 
<?php foreach ($this->pagesInRange as $page): ?> 
 <?php if ($page != $this->current): ?>
   <a href="<?= $this->url(array('page' => $page)); ?>"><?= $page; ?></a>
 <?php else: ?>
   <?= $page; ?>
 <?php endif; ?>
<?php endforeach; ?>
<?php if (isset($this->next)): ?> 
 <a href="<?= $this->url(array('page' => $this->next)); ?>">次へ</a>
<?php else: ?> 
 次へ
<?php endif; ?>  
<?php endif; ?>

以上で、selectした結果をグーグルのようにページ移動できるようになりました。


Zend Frameworkとコンソールの文字化け

データベースに接続するとき、文字コードを UTF-8 に設定すると回避できる。クイックスタートではbootstrap.phpを次にのようにした。

$dbAdapter = Zend_Db::factory($configuration->database);
// 文字コードを UTF-8 に設定する
$dbAdapter->query("set names 'utf8'");

Mysqlについて

接続

shudo@red:~$ mysql -u shudo -p

データベース一覧

mysql> SHOW DATABASES;

データベース選択

mysql> use tera;

テーブル一覧

mysql> SHOW TABLES;

CSVファイルをインポートする

mysql> LOAD DATA INFILE "meibo.csv" INTO TABLE kojins FIELDS TERMINATED BY ';' ENCLOSED BY '"';

CREATE TABLE構文のみ出力する

$ mysqldump -d -u hoge -p データベース名 > 出力ファイル名

AUTO_INCREMENTの開始番号を指定する。

mysql> ALTER TABLE hoge AUTO_INCREMENT=100;

データベースごとに文字コードを設定する。

mysql> SET NAMES utf8;        ....utf8,ujis

文字コードの確認

mysql> SHOW VARIABLES LIKE 'character\_set\_%';

phpからのクエリで文字化けするときの対策。

$db = mysql_connect("localhost", "hoge", "piyo");
mysql_select_db("poyo",$db);
mysql_query("SET NAMES utf8");


http://www.myspace.com/kungfoolfighting

EmEditor Freeのインストール

コマンドプロンプトから次のようにしました。--住職 2008年7月25日 (金) 14:18 (JST)

emed6004jfx.msi /passive

サラ川に 今年も映る 世相かな

私は57がお気に入りです。--住職 2008年7月21日 (月) 23:33 (JST)

西暦元号対照表

過去帳整理のときに便利です。--住職 2008年7月10日 (木) 17:05 (JST)


Debian 覚書 2008年