【PHP】下らねぇ質問はここに書き込みやがれ 65 at PHP
[2ch|▼Menu]
[1からを表示]
50:nobodyさん
08/02/27 15:33:09
CakePHP部分を取り除いて通常のPHPにしました。

これと似たような問題?バグであり回避は不可能なのかな?

php4で overload() して __call() を定義するとリファレンスで返せなくなる?
URLリンク(blog.livedoor.jp)

class A {
function foo(&$obj) {
$obj->value=2;
}

function __call($method, $params, &$return) {
return true;
}
}
overload('A');
class B {}

$a = new A();
$b = new B();
$b->value=1;
$a->foo($b);
print_r($b);

51:nobodyさん
08/02/27 15:37:55 lCPSweHG
どうにも不可解な事が起こったのでお時間ある方試していただけないでしょうか?
(長文なので3つに分けます。コード部分は2つです。すいません)
コードをさらします。UTF-8で保存してください。

session_start();
if(!isset($_SESSION['test'])){
$_SESSION['test'] = array(
array("name"=>"ほげ","age"=>32,"date"=>"2008-02-27 13:03:24.999999"),
array("name"=>"ふが","age"=>23,"date"=>"2008-02-27 13:03:24.333333"),
array("name"=>"おおおええええ","age"=>23,"date"=>"2008-02-27 13:03:24.999999"),
array("name"=>"文字化け","age"=>25,"date"=>"2008-02-27 13:03:24.333333"),
array("name"=>"最新","age"=>26,"date"=>"2008-02-27 13:03:24.111111"),
array("name"=>"ぼえぼえ","age"=>32,"date"=>"2008-02-27 13:03:24.666666"),
array("name"=>"おろろろ","age"=>25,"date"=>"2008-02-27 13:03:24.111111"),
array("name"=>"おえ","age"=>26,"date"=>"2008-02-27 13:03:24.666666"),
);
}
$order = array("age"=>SORT_DESC,"date"=>SORT_ASC);
_2KeySort($_SESSION['test'], $order);
$temp = $_SESSION['test'];
foreach($temp as $key=>$value){
$value['name'] = mb_convert_encoding($value['name'], 'SJIS', 'UTF-8');
$temp[$key] = $value;
}
echo "<pre>";
print_r($temp);
echo "</pre>";
echo "<pre style='background-color:#EEEEEE;'>";
print_r($_SESSION);
echo "</pre>";
//続く>>

52:51
08/02/27 15:38:37 lCPSweHG
//51の続き
function _2KeySort(array &$array, array &$columns_order){
$array_sort = array();
$array_order = array();
$i=0;
foreach($columns_order as $column => &$order){

if(!array_key_exists($column,reset($array))){
require_once 'Sd/Exception.php';
throw new Sd_Exception("ソートに指定されたキー[{$column}]がありません。");
}

foreach ($array as $key => &$row)
$array_sort[$i][] = $row[$column];

$array_order[$i] = $order;
++$i;
}

array_multisort($array_sort[0], $array_order[0], $array_sort[1], $array_order[1], $array);
}

53:51
08/02/27 15:39:26
>>51の続き
@まず、セッションに配列を保存。
Aセッションの配列をソート
Bセッションを別の変数に代入し文字コードを変換。
C代入した変数とセッションを表示

という流れです。
なぜか、セッションのデータも文字コードが変わってしまいます。しかも、全部ではありません。うちの環境では「おえ
」だけがUTF-8のままです。なので、表示の度に、めちゃめちゃに文字化けしていきます。

ちなみに、ソートする関数をコメントアウトすると、セッションの文字コードは変わらなくなります。
$temp = $_SESSION['test']というのは参照ではなく値のコピーですよね?
ソートする関数で、参照渡しにしなくていいところもありそうですが、それ以前に、セッションの文字コードに影響が出るのはおかしくないでしょうか?

実際には、Zend_Frameworkと、出力部分にSmartyを使用した、そこそこ大きなアプリで起こったことなのですが、
いろいろ試して、やっとここまで問題を切り分けました。

ソートする関数の参照渡しをやめるか、セッションに保存する前にSJISに変換して、出力の度に変換するのをやめれば
この問題は解決できるのですが、根本的な解決というか、理解になっていないので、気になります。たすけてください。
PHP Version 5.1.6です。

長文すいません。

54:nobodyさん
08/02/27 15:47:14
なんで肝心なとこだけ書かないの?
わざわざ回答者が全部見ると思う?

55:51
08/02/27 16:05:29
今、またいろいろ試してたのですが

ソートする関数内で、
array_multisortの為に、ソート対象カラムの配列を作るところのforeachで
foreach ($array as $key => &$row)

foreach ($array as $key => $row)
と参照をやめると、文字化けしないようです。
ここはソート対象カラムの配列のために、代入してる場所なので参照にする必要はなかったです。

なんかarray_multisortまわりか、参照渡しのバグっぽくないですか?

>>54
すいません。
これでもかなり問題を切り分けて、まとめて、要点のみ書いたんです。
ソースをそのまま実行できるように書いたほうが、いいのかなあ、なんて・・

せめて、53を最初に書いたほうがよかったかな。

読むのうざいと思いますが、そこを何とかお願いします

56:nobodyさん
08/02/27 16:06:20
>>51
たぶんmb_convert_encoding出来て無いんだと思う。

mb_language('Japanese');
$value['name'] = mb_convert_encoding($value['name'], 'SJIS', 'auto');

こうするとどうなる?

57:nobodyさん
08/02/27 16:09:21
autoはダメだろjk
ってか、なんでまたID隠し始めたんだ?51は

>>55
> なんかarray_multisortまわりか、参照渡しのバグっぽくないですか?
自分のソースをまず疑え
とPHPのえらい人が言ってました

どこで文字化けが起きてるかprint_rなどで各場所で文字化けがおきていないかチェックしたら?

58:nobodyさん
08/02/27 16:19:18
>>57
ダメだけど、ひょっとしたら自動変換してたら、と思って。

59:nobodyさん
08/02/27 16:48:18
未だに jk とか使ってる奴いるんだな。
生きてて恥ずかしくないか?

60:nobodyさん
08/02/27 17:05:32
j 女子
k 高生



61:nobodyさん
08/02/27 17:06:25
「常識的に考えて」

62:nobodyさん
08/02/27 17:27:05
>>61
KYは知っていたけどね。
おぢさん、初めて知ったよ。
ありがとう。早速今度の会議で使ってみるよ。

63:nobodyさん
08/02/27 17:31:36
危険予知は現場労働の基本だからな。

64:nobodyさん
08/02/27 17:33:00
>>62
おじさんごめんね
これ2ch発なんだ

65:nobodyさん
08/02/27 18:00:03
>>64
これがKYの良い例

66:nobodyさん
08/02/27 18:03:18 n+zWmSsJ
WindowsXP
apache 2.2
PHP Version 5.25

URLリンク(www.standpower.com)

↑ここを見て導入しました。

ファイル名 info.php

<?php
$hello="Hello World";
print ($hello);
?>

を作って
URLリンク(localhost)
を見てみると、「このファイルをダウンロードしますか?」となってinfo.phpをダウンロード
するかどうかのウィンドウが出てきます。どこか間違っているのでしょうか。

67:nobodyさん
08/02/27 18:06:22
Apacheの設定がおかしいんだろうから、とりあえず Apacheのエラーログ見れ。

68:nobodyさん
08/02/27 18:14:24
なんと分かりやすい

69:66
08/02/27 18:21:44
>>67

httpd.confの書き換えが間違っていたようです。
ありがとうございました。

70:51
08/02/27 18:29:48 lCPSweHG
>>56
$value['name'] = 'hogehoge';
でも元のセッションが変わってしまします。(同じく一部を除いて)

>>57
文字コードを変換してるforeachのなかで、元のセッションかわちゃってます。
IDは隠したわけじゃなく、連続で上げたら怒られるかなとおもって、sageにしちゃいました。


ためしに5.2.5が入ってるサーバーで試したら元のセッションは一切変わらず、問題なく動きました。
サーバーの設定かもしれませんが、基本php.iniはデフォルトのままで、.htaccessで設定してるので
見比べた感じ原因と思われるような違いはありません・・・

71:nobodyさん
08/02/27 18:38:00
欧文ならマトモに動作するんだよね?
sessionファイルをtmpから引きずり出して覗いて見るのは、さすがにキツい?

72:nobodyさん
08/02/27 20:26:06
解説サイト見てもよくわからんのですが
ログファイルを使ったページ分割のロジックはどういうものなんでしょうか?
記事数を1ページ辺りの記事表示数で割って表示しますよね。
その後の前のページに戻るとかのロジックがまったくよくわかりません。
スーパーグローバル関数のGETとか使うんですよね?

73:nobodyさん
08/02/27 20:30:05
>>7

74:nobodyさん
08/02/27 20:40:28
>>72
どこの解説サイト見てんの?

75:nobodyさん
08/02/27 21:25:22
URLリンク(www.phppro.jp)
ここなんですがユーザー関数とかに構造が分離されてて
自分の作りたいモノに流用すると複雑怪奇になりすぎて・・・

76:nobodyさん
08/02/27 22:10:24
前のページに戻る機能は現在のページから1引いた数をアンカーに付ければいいだけだと思うが。
そういう話じゃない?
全74件あって10件ずつ表示するなら、ページ5でリクエストが来たら41〜50件目の内容を、ページ4では31〜40件目の内容を取得すればいい。
ページごとに独立して考えればそんなに難しくないと思うけども。

77:nobodyさん
08/02/27 22:17:53
そのページ5で指示が来た時に該当件数を表示する
書き方がよく・・・・・・・
すべての投稿数数えて一ページあたりの表示数で割って
それから具体的にどうするんでしたっけ?
単に基礎知識足りなさ過ぎるだけなのか
頭が猛烈に足りないのか・・・・・・
htmlなら直感的にイメージ出切るぐらいまでそこそこわかるんですが
こういう二重、三重のロジックだとどうしても思考停止状態に陥ってしまうんですよね・・

78:nobodyさん
08/02/27 22:27:56
例えば総ページ数を番号で出すには
全体の投稿数を1ページ辺りの投稿数で割り余り分のためにページをプラス1して
表示するんですよね?
今度は表示したリンクをクリックした後に該当の投稿行をピックアップするように
またプログラムを用意すると・・・・あああ、ややこしい。

79:nobodyさん
08/02/27 22:35:21
君は向いてないね

80:nobodyさん
08/02/27 22:36:30
だと思います・・・・・
直感的なデザイン畑の人間ですし・・・・・

81:nobodyさん
08/02/27 22:38:42
はなむけに現在のページ数の受け取り方だけ教えてもらえませんか。

82:nobodyさん
08/02/27 22:41:10
>>7

83:nobodyさん
08/02/27 22:41:49
<?php

$page = $_GET['page'] ? $_GET['page'] : 1;

$all = countArticles();
$one = 10;

$start = ($page - 1) * $one + 1;
$end = $page * $one;

$articles = getArticles($start, $end);

こんな感じ?検証してないけど

84:nobodyさん
08/02/27 22:51:20
$allPages = cell(($all / $one));

echo "<p>総記事数は $all 件です</p>";
echo "<p>全部で $allPages ページあります</p>";
echo "<p>現在 $start 件目〜 $end 件目を表示しています</p>";
for($i=1; $i<$all; $i+=10){
if ($i == $page) {
echo '<a href="?page='.$i.'">['.$i.'] </a>';
} else {
echo '['.$i.'] ';
}
}

ついでにこんな感じ

85:nobodyさん
08/02/27 22:56:10 rbJ5iPpD
DBに保存してある画像のバイナリデータ(形式はjpeg,gif,png)をリサイズしたい場合はどうすればよいのでしょうか。
php4.3のGD入ってます

一旦ファイルに保存してimagecreatefromjpegとかするしかないのでしょうか。
そんな馬鹿な。

86:nobodyさん
08/02/27 22:56:22
間違えた。最後のfor文は素直に
for($i=1; $i <= $allPages; $i++){
でokだ。
全ページ数を使わないで出力するなら$iのインクリメント用と記事数比較用の2変数使えばできる。まぁ蛇足だが。

87:nobodyさん
08/02/27 22:57:21
>>85
お怒りはごもっともですが
現在、この世界のいたるところで
あなたの言う『ばかなこと』が起きています

88:nobodyさん
08/02/27 22:59:30 rbJ5iPpD
めっけた。
imagecreatefromstring

これでいい気がしてきた。

89:nobodyさん
08/02/27 23:17:29
課題だとか勉強用だとかじゃなければ素直にそのへんのpager使えばいいのに

90:nobodyさん
08/02/28 00:03:25
WebARENA SuiteX
PHP5
で、次のアップロードスクリプトを設置しています。
URLリンク(hellogirls.myphotos.cc)

Suite2 PHP4の時は問題なく動作していたのですが、SuiteXにしたらアップロードファイルにつけるコメントに日本語が含まれていると文字化けするようになりました。
色々、調べてみましたがちんぷんかんぷんで解決策がわかりません。
この辺りのソースをいじれば良さそうな気がするのですが…

どなたかアドバイスやヒントでもいいのでいただけないでしょうか。
PHPやCGIの設置はできるけど、プログラムの具体的なことは何も理解できてません。
こんな私ですがどうかよろしくお願いします。

コメント
<input type="text" size="45" name="com" value="'.($c_comu ? $input_comment : '').'">

//ファイルリスト表示
if($c_com) echo '<td class="column_comment">'.$com.'</td>';

//項目読み取り
list($id,$ext,$com,$host,$now,$size,$mtype,,$orig,,$img_width,$img_height) = explode("\t",$logline);

91:nobodyさん
08/02/28 00:13:47
>>90
めんどくさいから見てないけど少なくとも出されてるソースは関係ない。
スクリプト改造依頼スレがあるからそっちいくよろし。

スレリンク(php板)
スレリンク(php板)
この辺かな

92:nobodyさん
08/02/28 00:22:13
PHP4からPHP5の仕様変更が文字化けの原因みたいで、それでこちらのスレに誘導されてきたのですが。
改造スレに行ったら、それは改造ではなくPHPの仕様の問題だからPHPスレで聞けと言われそうです。

93:nobodyさん
08/02/28 00:46:33
>>90
PHP4.4.x(PHP5では動作確認していません)
と書いてあるので諦めろ……

ソースみたけど、PHP4に依存してる場所はなさそうだったけどね。
form_upload_file.phpをいじってるのなら、文字コードがSJISになっていないか確認。
きちんとEUC-JPになっているか?

ログファイルをエディタで開いて見て、EUC-JPで文字化けしないかどうか。

そのあたり確認して報告しろ。 寝るのでまた明日。

94:nobodyさん
08/02/28 06:33:06
ありがとうございます。

form_upload_file.phpはEUC-JPになっていました。
ログファイルを確認したところ、日本語で文字化けしているコメント部分もログファイルではまだ文字化けしていませんでした。

ログファイルを読み出して表示するまでの過程で文字化けがおこっているようです。

95:nobodyさん
08/02/28 09:55:35 OSai0GdG
PEAR::DBを使ってデータをINSERTする作業をしているのですが、
debug_backtrace();の部分で、エラーが出ます。
数万〜数十万ほどINSERTを繰り返すループなのですが・・・

96:nobodyさん
08/02/28 11:14:01 hOKfamSR
質問です。
CentOS5のディストリビューションを使って環境構築したのですが、画像やファイル情報をphpを使用して、PostgreSQLにbyteaでコミットをする時にmemory_limitが不足する現象が起きています。

<確認している現象>
・2MBの画像のコミット時にはmemory_limitに53MB以上が必要
・4MBの場合は、128MB以上
・8MBの場合は、400MB以上
といった具合です。

<環境>

OS :CentOS5
WEB:Apache/2.2.3 (CentOS)
PHP:PHP Version 5.1.6
DB :PostgreSQL8.1.9

windowsやRedhatで同じphpなどで構成し、モジュールを実行した際には8MBのファイルでもデフォルトのmemory_limitの設定である16MBで問題なくコミットできました。
他の環境でも検証していきますが、この原因って何が考えられますでしょうか。

97:nobodyさん
08/02/28 11:50:28
質問です。

$word = $_GET[WORD];
$word = mb_convert_encoding($word,"SJIS","UTF-8");

PHP5(WebARENA SuiteX)なのですが、大部分はこれでデータの受け渡しは問題あり
ません。

しかし、"90's"を受け渡す際に"90\'s"になってしまいます。stripslashesを使え
ば解決できることはできるのですが、今度はこれを使うと"ソニー"を受け渡す際
に文字化けしてしまいます。

"90's"も"ソニー"も問題なく受け渡す方法を教えていただけないでしょうか。

98:nobodyさん
08/02/28 11:53:14
>>97
>>7

99:97
08/02/28 11:59:15 AxRhgNfU
>>98
申し訳ない。「自分のIDを表示させること。」というのを見逃してました。

100:nobodyさん
08/02/28 12:00:27
>>99
php.iniの設定でクオートが自動でされる設定になってるんじゃまいか?
auto_magic_quoteだっけ?

101:nobodyさん
08/02/28 12:02:50 z722MoHc
URLリンク(niwango.jp) にある

現在の評価は
Good![2] Bad![0]

的なPHPってどんな仕組みなんだろ・・・

102:nobodyさん
08/02/28 12:12:19 AxRhgNfU
SuiteXは共有サーバーなのでphp.iniをいじれないんですよ…。
何かプログラム的に逃げる手があればいいのですが…。


103:nobodyさん
08/02/28 12:13:59
PHP内で一時的にPHP.iniの設定を変更できるini_set()関数がある

104:nobodyさん
08/02/28 12:49:43
>>100
magic quotes gpc じゃないか?

>>103
>magic_quotes_gpcは 実行時にセットしても反映されないことに 留意してください。
って書いてあるけど、できるの?
URLリンク(www.php.net)

stripslashes してから UTF-8に変換しても化けるのかな?よくわからん。

105:nobodyさん
08/02/28 12:53:22
たぶん受け取る前に書けばできるはず
不安だったらhtaccessで設定すればいいし・・・

106:nobodyさん
08/02/28 12:57:37
>>105
受け取る前っていつ?
PHPのモジュールが呼び出された時点では $_GET / $_POST に値が設定されてるんじゃないの?

107:nobodyさん
08/02/28 13:15:22
試したけど、やっぱムリじゃね。(PHP5.2 WinXP)

ini_set('magic_quotes_gpc', 'Off');
print_r($_GET);

マニュアル見ると

magic_quotes_gpc
 PHP_INI_PERDIR
 PHP <= 4.2.3 では PHP_INI_ALL。PHP 6.0.0 で削除。
URLリンク(jp2.php.net)

ってなってるけど、PHP4はPHP_INI_ALLだから出来たという事なのかな。
値の参照時にでも処理してたんだろうか。これもよくわからん。


108:nobodyさん
08/02/28 13:16:55 AxRhgNfU
皆さんお昼休みなのにありがとう。SuiteXは個人で使っているので、家に帰ってから色々と試してみます。

>>103
その発想なかったです。試してみますね。

>>104
順番を変えるのもちょっとやってみますね。

>>105 >>106
受け渡し前はごく普通のHTMLです。
<form action="XXXX.php" method="get" name="form1">
<input type="text" name="WORD">
モジュールが呼び足された時点で値が設定されてしまいますね。

109:nobodyさん
08/02/28 13:22:10 AxRhgNfU
>>107
PHP4(WebARENA Suite2)の時にはこれだけで動いてました。

$word = $_GET[WORD];
$word = stripslashes($word);

文字化けもなく不要な"\"も出てきませんでした。PHP4では逆にmb_convert_encoding
でエンコード変換すると文字化けしてしまってました。

110:nobodyさん
08/02/28 15:48:07 SiLzRmwx
mb_send_mailをして受け取ったメールを見ると、行間が1行ぐらい空きます。
サーバはEUCなので、
mb_language("Japanese");
mb_internal_encoding("EUC-JP");

という指定を入れています。どうしてこうなるのでしょうか?

111:nobodyさん
08/02/28 15:49:46
改行コードが入ってるからじゃね?

112:110
08/02/28 16:01:23 SiLzRmwx
>>111
改行コードを取り除くのに、↓を入れたのですが、特に変わりません。。

$body = str_replace("\r", "\n", str_replace("\r\n", "\n", $body));

113:nobodyさん
08/02/28 16:07:18
>>112
取り除いてねーじゃん
置き換えてるだけじゃねーか

str_replace(array("\r\n", "\r", "\n"), "[改行]", $body);
みたいにして、BODYの中での改行なのか他で改行入ってるのか調べてみれ

114:nobodyさん
08/02/28 18:38:26
>>101
vote.php?id=17685&value=1

115:nobodyさん
08/02/28 18:41:37
このスレ来ると和むな〜

116:nobodyさん
08/02/28 19:31:54
すみません。助けてください。
HTMLとPHPとがまじったファイルがあるんですけど、シンタックスエラーがでます。
どうやら '}' をひとつ抜かしてしまったみたいなんですが、どこで抜かしてしまったかがエラーメッセージからは分かりません。
ファイルはHTMLとPHPとが混ざった500行を超えるファイルです。
正直、どうやって探せばいいのかわかりません。
こんなとき、みなさんどうしてますか。

117:nobodyさん
08/02/28 19:34:58
対応する括弧が強調表示されるエディタを使ってチェック

118:nobodyさん
08/02/28 19:36:01
エディタ(自分の場合はEmacs)使ってインデントつける。

119:108
08/02/28 19:53:20 s0/KCSkK
>>104
108ですが家に帰ってきました。
そして、順番を変えてmb_convert_encodingの前にstripslashes置いたら
ちゃんと動作するようになりました!

$word = $_GET[WORD];
$word = stripslashes($word);
$word = mb_convert_encoding($word,"SJIS","UTF-8");

104さん本当にありがとうございました。
あと他にコメントいただいた皆さんもありがとうございました。

120:nobodyさん
08/02/28 20:22:44
>>116
ファイルから PHP だけを抜き出して調べるというのはどう?
URLリンク(d.hatena.ne.jp)
HTMLとPHPが入り交じっているから見つけるのが難しいのであって、HTMLを消してPHPだけにできれば、けっこう簡単に見つかるかもよ。


121:nobodyさん
08/02/28 21:00:56 UIzvtCsy
PHPのクラスについて理解が深くないのですが、
PHP5.1.6で以下のコードを書いたときの疑問です。
class Stack {
  public function getInstance() {
    return new Stack();
  }
}

$stack = Stack::getInstance();
の様に、static宣言されずに::を使ってメソッドにアクセスできるのはなぜですか?

122:nobodyさん
08/02/28 21:02:53
>>121
PHPがアバウトだから

123:nobodyさん
08/02/28 21:03:18
>>121
PHP4との互換性のため。
ただしstaticつけると Stack::getInstance() はOKでも $stack->getInstance() はエラー。


124:nobodyさん
08/02/28 21:06:14 UIzvtCsy
>>122
それは日ごろ確かに感じます。こだわりがないって。

>>123
staticをつけなくてもstaticに呼び出されているんですか?

125:nobodyさん
08/02/28 21:23:56
試してみりゃすぐ分かるがな

126:nobodyさん
08/02/28 21:42:59
掲示板のフォームから内容受け取って
150個のログ以上は消すと言うロジックはみなさんどうしてます?
file()で全ログ格納してからarray_unshiftで新しい内容を挿入、
その後forを使って何かするんでしょうけどそこが具体的によくわかりません。

>>84
ありがとうございます、
おかげさまでできました。
本当に感謝です。

127:nobodyさん
08/02/28 21:52:28
>>124
>staticをつけなくてもstaticに呼び出されているんですか?

yes

PHPでは static に呼び出すのも、static じゃない呼び出しも、どっちも同じ。
たんに、static な呼び出しだと $this にアクセスできないというだけ。

128:nobodyさん
08/02/28 22:11:56
staticで呼び出す方が遅い訳だが

129:nobodyさん
08/02/28 23:06:49 CZGTxiZs
あらやだ、ホントだ
PHP 5.2.3

class foo
{
  var $buf = null;
  function foo() { $this->buf = 100; }
  function static_func() { return 100; }
  function member_func() { return $this->buf; }
}

-- call foo::static_func 10000 * 1000
min: 0.0476429462433
max: 0.0605020523071
ave: 48.9423131943
-- call foo->member_func 10000 * 1000
min: 0.0209789276123
max: 0.0423769950867
ave: 21.8284888268

なんで?

130:nobodyさん
08/02/28 23:42:39 psOQg9xE
PDOでfetch()を使うとfetchAll()を使うように怒られるのがむかつく。
仕様なんですか?

131:nobodyさん
08/02/29 00:07:06
過去のいきさつはよくわからないのだけど
magic_quote_gpcとかregister_globalsとか
過去の遺産も簡易FAQに入れたがいいのかなぁとか思った。

個人的には今更そういう設定のサーバがあること自体が不思議なんだけど
99を見る限りまだ生きてるっぽいし
逆に、そういう動作があるっていうのを知らない人が増えてきた今だからこそ
問題だとか思うんだ。

というわけで解説よろしく


132:nobodyさん
08/02/29 00:15:13
解説じゃないけど。

>個人的には今更そういう設定のサーバがあること自体が不思議なんだけど

PHP5 では magic_quote_gpc はデフォルトで On だからなぁ。

133:nobodyさん
08/02/29 00:20:59
PHPの設定で
magic_quote_gpcというものがあって、
これがONであるとPOSTとかGETの中身は渡された先で勝手にクオートされます。

面倒なのは、同じスクリプトでもサーバーのPHPの設定によって
挙動が異なってしまうことです。

これを防ぐためには、
自サバならばPHP.iniのmagic_quote_gpcをoffにしてください。
そうでないならば、
$_POST,$_GET配列をまず最初に処理する関数を作り、その中に

if(get_magic_quote_gpc()){
として、各要素をstrip処理すれば良いと思います。
ini_set()はなにやらオススメできないようです。


134:nobodyさん
08/02/29 00:26:04
最後の2行が随分曖昧だな

135:nobodyさん
08/02/29 00:30:05
>>134 めんどくなった。
ついでに俺130なんで誰か答えてくれ。

136:nobodyさん
08/02/29 00:39:04
怒られるって誰に?上司に?

137:nobodyさん
08/02/29 00:44:55
PDOに怒られます。
Uncaught exception 'PDOException' with message
'SQLSTATE[HY000]:
General error: 2014
Cannot execute queries while other unbuffered queries are active.
Consider using PDOStatement::fetchAll().
Alternatively, if your code is only ever going to run against mysql,
you may enable query buffering by setting the PDO::MYSQL_ATTR_USE_BUFFERED_QUERY attribute.'

と言われます。

138:nobodyさん
08/02/29 00:46:34
コードがおかしいんだべ。

139:nobodyさん
08/02/29 00:47:38
いくつも仕事を同時にさせるな、ボケって言われてるだけじゃないの?

140:nobodyさん
08/02/29 00:50:06 lB4w3WIe
誰もなったことないの?
誰もPDO使ったことないってことか?
そこをfetchAll()にすると直るんだけど、
fetchAllって名前から想像つくと思うけど全行読むから
メモリもったいないかと思って。


141:132
08/02/29 01:06:54
>>133
偉いっ!!すばらしいっ!!結婚して!!!当方マンションもち。

もっと単純に

自分でPHP.ini触れるんならmagic_quote_gpcはoff
触れないんだったら全てのスクリプトで(なんだっけ)せれ
質問はその後だ

みたいに強制的でもいいのかでもとか思った。


142:nobodyさん
08/02/29 01:42:07
「誰もなったことない」 ⇒ 「誰もPDO使ったことない」
素晴らしい推論能力をお持ちのようで。

まぁそんなことはさておき、コード出してみたら?恐らく普通とは違う書き方してるんだろうし。

143:nobodyさん
08/02/29 02:06:51 lB4w3WIe
$rs=$db->query("SELECT UNKONAME FROM UNKOTABLE WHERE UNKO_ID=1");
$unko=$rs->fetch();
echo $unko["UNKONAME"];

$rs2=$db->query("SELECT UNKONAME FROM UNKOTABLE WHERE UNKO_ID=2");
$unko2=$rs2->fetch();
echo $unko2["UNKONAME"];

みたいな感じにSQLを2回やるとなんか怒られます。
fetchAllにして、1個しかない結果セットを$unko[0]["UNKONAME"]
とかやって取り出せるんだけどね。

144:nobodyさん
08/02/29 02:07:51 lB4w3WIe
分かると思うけど$dbはPDOのインスタンスです

145:nobodyさん
08/02/29 02:23:09
PDOはよく知らんが、このあたりの話じゃないの?
URLリンク(jp2.php.net)


146:nobodyさん
08/02/29 02:38:03
URLリンク(jp2.php.net)
PDO->query() を次にコールする前に 結果セット内の全てのデータを取得しない場合、そのコールは失敗します。
PDOStatement->closeCursor() をコールし、 次に PDO->query() をコールする前に PDOStatement オブジェクトに
関連付けられたリソースを解放してください。

147:nobodyさん
08/02/29 02:43:19 lB4w3WIe
>>145>>146
ありがとうございました。

148:nobodyさん
08/02/29 09:47:17
static
○ Object::obj();
× $obj->obj();
○ $this->obj();

public
○ Object::obj();
○ $obj->obj();
○ $this->obj();

protected
× Object::obj();
○ $obj->obj();
○ $this->obj();

private
× Object::obj();
× $obj->obj();
○ $this->obj();

これでおk?

149:nobodyさん
08/02/29 10:50:21
>>148 だめー
大体にしてメソッド名をobjにするなややこしい。
コンストラクタかと思うじゃねーか。
そもそもそういう理解の仕方じゃまずいぞ。

privateなメソッドというのは「class hoge{}の外からのアクセスは完全にNG」て意味。
中からなら$this->やObject::obj()でアクセス可能って意味だ。外から$thisなんてことはできないので$obj->objかObject::objを使うことになるけど、
それらのアクセスはprivateじゃ無理よってこと。

protectedは継承したクラスもアクセス可能という意味。だから、class fuga extends hoge{}はhogeのprotectedなメソッドを
$thisとかObject::objで扱うことができるってこった。だが当然インスタンス生成してのアクセスである$obj->objは不可能だし、
外部からのObject::objも不可能。

publicは外からのアクセスもできる。$thisだろうとObject::objだろうとOKだ。

staticは上記3つとは別な概念。上記3つは同時に存在できないが、こちらはpublic staticのように併存OKだ。
staticなメソッドは、「外部からそのクラスのインスタンス生成なしで呼び出すことのできるメソッド」
と言う意味。でも重要なのは「staticと指定したメソッドは、そのクラスのstaticでないプロパティや
メソッドを呼び出せない」ってこと。staticでないメソッドやプロパティを呼び出してるメソッドにstaticを設定すると
エラーが出るはず。staticなメソッドはぶっちゃけて言うと一般の関数と変わらない使い方ができる。
PHPみたいなゆるい言語においては微妙な存在ってこった。ただ、「こういう処理をする関数はここにまとめておこう」みたいなときに
使ったりするね。

150:nobodyさん
08/02/29 11:21:01
>>149がはりきっております

151:nobodyさん
08/02/29 11:33:03
>>150うるせーこっちは13時から試験があるから逃避してんだよw

152:nobodyさん
08/02/29 11:53:10
この$noを求めるのに前のログの$noに+1して
書き込む処理をこの上でしてるんですが
それだと書き込みが重複した時にナンバーが同じ値になったりするのでしょうか?
削除に使うナンバーなのでなるべく厳密になるようにしたいのですが。

$data = "$no\t$name\t$comment\t$delkey\t$time\n";
$filename = ('card.txt');
$log = file($filename);
$handle = fopen($filename, "w");
flock($handle,LOCK_EX);
fwrite($handle,$data);
for($i=0; $i<150; $i++) {
fwrite($handle,$log[$i]);
}
flock($handle,LOCK_UN);
fclose($handle);

153:nobodyさん
08/02/29 11:57:51
>>7

154:nobodyさん
08/02/29 12:26:21
>>152
厳密にやるならデータベースを使う。
データベースが使えないなら、uniq_id()やmd5(microtime(true))で重複しない乱数で代用する。

155:nobodyさん
08/02/29 12:42:52
$no+1する前の段階でファイルロック掛けておけばいいんじゃ?

156:nobodyさん
08/02/29 12:44:33
ありがとうございますmd5(microtime(true))でやってみます、
多分私の扱える知識がないデータベース以外で精度が高いのは
これだと思うので。
これで作り出したIDが重複してないかファイル捜索するのは時間の無駄ですかね?

157:nobodyさん
08/02/29 12:46:02
>>149
staticなプロパティは異なるインスタンス間で値を共有できるから便利

158:nobodyさん
08/02/29 12:49:40
え?
fopenする前にファイルロックできるんですか?
ちょっと最近勉強始めたのでよくわかってないのですが。



159:nobodyさん
08/02/29 12:54:20
こういうことですかね。

$filename = ('card.txt');
flock($filename,LOCK_EX);
$log = file($filename);
$no = explode("\t", $log[$i])
$data = "$no[0]\t$name\t$comment\t$delkey\t$time\n";
$handle = fopen($filename, "w");
fwrite($handle,$data);
for($i=0; $i<150; $i++) {
fwrite($handle,$log[$i]);
}
flock($handle,LOCK_UN);
fclose($handle);

160:nobodyさん
08/02/29 12:59:01
>>156
md5だけなら重複する可能性があります。

161:nobodyさん
08/02/29 13:05:26
ロック用ファイルを別に作ってもいいけど155で言いたかったのは

1.ファイルオープン(a+)
2.ファイルロック
3.ファイル中の最新の番号を取得
4.番号を1増やす
5.新しい記事を追記
6.ファイルロック解除
7.ファイルクローズ

的な感じ。いつもDB使ってるからファイル関係はよく知らんけど。

162:nobodyさん
08/02/29 13:06:34
>>159ひどいな・・・・
fopen時にw以外で読み書き可能なものを選ぶと言うことか・・・・
でもそうするとログ追記型で過去ログ削除できなかったりとややこしい・・・・

>>160
それを元に乱数生成とかですよね、多分。

163:nobodyさん
08/02/29 13:08:16
>>161
ご丁寧にすいません、その後記事の数を決めた定数以内にしたい場合、
何かいい方法ないでしょうか?

164:nobodyさん
08/02/29 15:35:33
>>163
プログラム云々依然にロジックの質問かよ!

165:nobodyさん
08/02/29 15:56:02 SImzeFcn
includeしたファイルが数値だと普通に表示されますが
日本語文字列だと表示されません。

文字コードの設定だとは思いますがお教えください。

166:nobodyさん
08/02/29 15:58:43
文字コードの設定を正しくする。

それ以上何を言えばいいんだ?

167:165
08/02/29 16:05:45 SImzeFcn
>>166
文字コードの設定の仕方が分かりません。
現状では<meta http-equiv="Content-Type" content="text/html; charset=euc-jp" />
にしていますが文字化けしてしまいます。

shift_jisだと全てが文字化けしてしまいます・・。

168:nobodyさん
08/02/29 16:07:43
もう何もかもが

169:nobodyさん
08/02/29 16:08:15
突っ込んだら負けってヤツ?

170:nobodyさん
08/02/29 16:10:45
>>167
その読み込む側のファイル晒して

>>168-169
お前らこのスレに向かないんじゃない?答える気もないなら来んなよ

171:167
08/02/29 16:14:27 SImzeFcn
// サイトURL
$url = "URLリンク(example.ex)";

// サイトネーム
$site_name = "日本語文字列";

// サイトサブタイトル
$sub_title = "日本語文字列";

// 現在時刻を取得
$time = getdate();

>>170
こんな感じで書いています。

172:nobodyさん
08/02/29 16:15:29
(・∀・)ニヤニヤ

173:167
08/02/29 16:18:39 SImzeFcn
>>168-169
>>172
やっぱいいです
頑張ってみます

>>170さんありがとうございます

174:nobodyさん
08/02/29 16:22:44
>>173(´;ω;`)ブワッ

175:nobodyさん
08/02/29 16:23:04
>>170
ほらほら、最後まで面倒みろよ

176:nobodyさん
08/02/29 16:25:35
>>168-169 >>172 >>175
性格悪すぎワロタwwwww

177:nobodyさん
08/02/29 19:02:38 TvsAPhPQ
図1           図2
             .
○            .バックアップ
├ fo          └○
│ ├ test2        ├ fo
│ │ ├ a.txt    ..  │ ├ test2
│ │ ├ b.txt    ..  │ │ ├ a.txt
│ │ └ c.txt    ..  │ │ ├ b.txt
│ └ testfile.txt     │ │ └ c.txt
└ test.txt      ..  │ └ testfile.txt
               └ test.txt


図1を図2のようにバックアップフォルダにコピーしたいのですが
よい方法はありませんでしょうか?
なにとぞご教授お願いします

178:nobodyさん
08/02/29 19:24:53
図を作る努力をphpに振り向けるんだ!

179:nobodyさん
08/02/29 19:28:32
答える気の無いヤツと答えるフリして逃げるヤツしかいないのか

180:nobodyさん
08/02/29 19:34:00
OSが決まってるなら xcopy なり cp -r を呼び出せば?
URLリンク(jp2.php.net)

181:nobodyさん
08/02/29 19:59:47
うーん外部コマンド以外の方法があればどなたかお願いいたします

182:nobodyさん
08/02/29 20:01:45
<?php
define( "srcDir", "○" );
define( "dstDir", "バックアップ" );
dircopy( srcDir, dstDir );

function dircopy($srcdir, $dstdir, $verbose = false) {
$num = 0;
if(!is_dir($dstdir)) mkdir($dstdir);
if($curdir = opendir($srcdir)) {
while($file = readdir($curdir)) {
if($file != '.' && $file != '..') {
$srcfile = $srcdir . '\\' . $file;
$dstfile = $dstdir . '\\' . $file;
if(is_file($srcfile)) {
if(is_file($dstfile)) $ow = filemtime($srcfile) - filemtime($dstfile); else $ow = 1;
if($ow > 0) {
if($verbose) echo "Copying '$srcfile' to '$dstfile'...";
if(copy($srcfile, $dstfile)) {
touch($dstfile, filemtime($srcfile)); $num++;
if($verbose) echo "OK\n";}
else echo "Error: File '$srcfile' could not be copied!\n";}}
else if(is_dir($srcfile)) {
$num += dircopy($srcfile, $dstfile, $verbose);}}}closedir($curdir);}
return $num;}
?>

これでおkだろ

183:nobodyさん
08/02/29 20:03:15
>>182
ありがとうございます!!!!!
助かりました!!

184:nobodyさん
08/02/29 21:51:10
xamppをインストールし、URLリンク(hiromasa.zone.ne.jp) を参考に設定してましたが
誤って、「root:localhost」を特権から削除してしまいphpMyAdminにアクセスできなくなってしまいました。

再インストールしても状況が戻らずどうしていいのか・・・

185:nobodyさん
08/02/29 23:47:35
>>184
OSは?
再インストールってどうやった?
俺もやったことあるけど復活させたぞ

186:nobodyさん
08/03/01 00:03:26
>>185
XP homeです。
再インスコはOSではなくてソフト入れなおしただけです・・・

187:nobodyさん
08/03/01 00:11:45
>>186
アンインストールは単なる削除か?
要は「システム」としてインストールしたMySQL(とかXAMPP)が
アンインストールされてないとお話にならないってわけだよ。

アンインストールしてなくてもroot権限でMySQLに入れるなら
GRANTとかで治るとおもうけど、
一応再インストールとか厄介なことしたわけだから、
完全にアンインストールすることを強く勧める。
で、
Windowsの コントロールパネル>管理ツール>サービス
を開き、その中にmysqlとかXAMPP Serviceってのはあるか?


188:nobodyさん
08/03/01 01:45:42
>>187
プログラムの追加と削除からのアンインストールです。
サービスの中は両方ともにありませんでした。。。

189:nobodyさん
08/03/01 01:58:22
どーでもいいがDB板向けな話題だなw


190:nobodyさん
08/03/01 02:44:24
>>186
C:WINDOWSに'my.ini'が残っているとか?
関係ないか...。

191:nobodyさん
08/03/01 02:58:59 Nw5SqNkj
素人ですが教えて下さい。

ユーザーが投稿する写真のサムネイルを表示したいと思っています。
私が読んでる参考書に表示スピードを考慮した画像縮小方法として、GDライブラリが紹介されていました。
しかしGDライブラリは指定したサイズに縮小するだけのように思えます。間違ってたらすいません。

投稿される写真のサイズはバラバラで、縦長の写真、横長の写真、正方形の写真など様々です。
縦長は縦長のまま、横長は横長のまま、正方形は正方形のままに縮小したい(mixiのマイミク一覧のよう
な感じ)のですが、一般的にはどうのように行っているのでしょうか?ヒントだけでもお願いします。

192:nobodyさん
08/03/01 03:47:22
>>191
算数の素人さんですか

100x100を半分にすると50x50
100x200を半分にすると50x100

指定したサイズに縮小できたら十分。

193:nobodyさん
08/03/01 05:15:24
高さと幅の最大値を決めて、あとはそれに合うようにアスペクト比をあわせればおk
どっちかの小さい方にあわせんだっけかな

194:nobodyさん
08/03/01 13:12:12
縦書きの日本語をGDで表示したいんだけど
横書き用フォントでは







ってカンジに表示されてしまう
どうやったら縦書き用フォントが使えるんですか?

195:nobodyさん
08/03/01 13:24:38
>>7

196:nobodyさん
08/03/01 13:29:45
>>195
このスレはこの程度か
ありがとうございました

197:nobodyさん
08/03/01 13:42:39
>>196
>>7よりググレカスの方が正しいかも

「GD フォント指定」でそれっぽいのが出てくるのに
悔しくて捨て台詞をいう程度のカスなんでしゃーないなぁ

198:191
08/03/01 14:01:50 Nw5SqNkj
>>192
すいません、質問が悪かったと思います。
元の大きさがバラバラなので、ただ半分にしただけじゃ並べたときにデコボコになります。
縦横の比率を保ったまま、縮小後の大きさを大体同じ大きさにしたいのです。

200×100は1/2で100×50
400×400は1/4で100×100
250×500は1/5で50×100

というふうに大体100×100の枠に納めたいのですが、元の写真がどのサイズで来るか分かりません。
GDライブラリは試してないのですが、100×100へ縮小としてしまうと、正方形の写真以外は歪ん
でしまうんじゃないでしょうか?

歪ませずに大体100×100の大きさに納めるにはどうすれば良いでしょうか?

199:nobodyさん
08/03/01 14:03:57
だから長いほうを100pxにすればいいじゃん

200:nobodyさん
08/03/01 14:04:59
>>198
リアル算数素人だった、この衝撃

201:194
08/03/01 14:22:00 z6e/g20g
>>196
ちょwwwなにやってんだ

>>197
おれは196じゃないです
ID表示させとけばよかった
「GD 縦書き」とかで検索しても出なかったんで聞いてみたんです。
縦書きに切り替える関数とかあるのかな?


202:194
08/03/01 14:24:36 z6e/g20g
縦書き専用フォントを使えばいいのかな?

203:194
08/03/01 14:29:55
>>201-202
偽者

204:nobodyさん
08/03/01 15:21:32 MLWBh96T
質問です。

アップローダーを作っているのですが、
アップロードファイルのローカルパスの一部をファイル名と認識してしまい難儀しております。

入力フォームで
”C:\Documents and Settings\User\デスクトップ\sample.doc”
と入力して
$_FILES[ パラメータ名 ][ name ]で
ファイル名を抽出すると
”デスクトップ\\sample.doc”
とでてきてしまいます。

環境
PHP 5.2.5
Apache/1.3.41

対処法をご存じの方、ご教授をお願いします。

205:nobodyさん
08/03/01 16:27:41 SX7Jze++
質問です

4択式のリアルタイムアンケートを作成したいのですがご教授ください


ページで投票してもらって
最終的に各回答の合計数がカンマ区切りの○○○.txtというデータで吐き出されればよいです。
ビジュアルとかはこだわりません。

206:nobodyさん
08/03/01 16:44:55
>>205
宿題は自分でやりましょう

207:nobodyさん
08/03/01 17:03:11 bS1QPxn9
質問させてください

$url = "URLリンク(www.unko.com)";

ここから、URLリンク(www.test.com)のみを取得したいのですがどのような関数を使えば良いでしょうか?

URLリンク(www.unko.com) は固定されていますが、

?unko_id=12345 は ?oomoriunko_id=123 になったり ?geriunko_id=111111111 になったり

固定されていないものとする。

以上ぎょきょうじゅくださいお願いします

208:nobodyさん
08/03/01 17:07:45
preg_match

209:nobodyさん
08/03/01 17:12:33 bS1QPxn9
>>208
ありがとうございます
なんとなく理解できました

あと書き忘れたのですがtest.htmlも固定されてません。

もう少し調べてみます

210:nobodyさん
08/03/01 18:50:49
mysql_escape_string と
mysql_real_escape_string の違いについて、

後者は文字コードを考慮する、とマニュアルには記載されていますが、
結果として、
後者ではなく、前者を使用していると
脆弱性が発生したりするケースはあるのでしょうか。


211:nobodyさん
08/03/01 19:16:54
>>187
亀ですみません。
root権限で入ろうと思いますが、その方法がわかりません。
差し支えなければ教えていただけませんか?

212:nobodyさん
08/03/01 19:34:15
>>210
前者は非常に危険です。
後者でも危険性が指摘されています。

213:nobodyさん
08/03/01 19:59:50
>>212
ソース

214:nobodyさん
08/03/01 20:03:33
質問スレだか、初心者いびりスレだかわかんなくなってきてるな……。

215:nobodyさん
08/03/01 20:10:28
>>211
> mysql -u root -p

216:nobodyさん
08/03/01 20:46:02
>>207
parse_url

217:nobodyさん
08/03/01 20:46:29
>>221
DB板行けよ
MySQL 総合 Part13
スレリンク(db板)

>>214
初心者スレは初心者スレがある
くだすれPHP(超初心者用)3
スレリンク(php板)

218:nobodyさん
08/03/01 20:55:00
>>214
このスレには初心者は来ていませんよ?

少なくともマニュアルを一通り目を通したりぐぐったりしてきてるはずなんで。

219:nobodyさん
08/03/01 21:06:57 Y1gVmTFW
開発をWindowXPでやってます
PDO::exec()でクエリを実行する場合影響した行数が帰ってくるはずですが、まったく影響のないクエリを実行してるのに1が返ってきます
バグでしょうか?

apache2.2
php 5.2.5
Postgresql 8.2

220:nobodyさん
08/03/01 21:13:47
はい、バグです。
次の方どうそー。

221:nobodyさん
08/03/01 22:02:10
>>219
DBMSによっては、delete で全行削除した場合、削除した行数を返さないらしい。
必要な場合は、where 1=1 ってやるのが定石だそうだ。

postgresをPDOで使ったときに同じ問題があるかどうかは知らない。


次ページ
最新レス表示
スレッドの検索
類似スレ一覧
話題のニュース
おまかせリスト
▼オプションを表示
暇つぶし2ch

5366日前に更新/145 KB
担当:undef