インターネットの話」カテゴリーアーカイブ

Swiperを設置したホームページを作ってみる

2019年4月9日

PHPで検索表示できるページとして激安の中古戸建てのページを試作してみたのですが、一覧表示のページからリンクされた詳細ページにおいて、Swiperを使って複数の画像を手動で入れ替えるようにしようと思っています。

ページによって画像の数が違うので、Swiperを使ったほうが、すっきりしたページになるんです。
せっかくなので、PHPでMySQLからデータを読み込むようにしようと思います。

とりあえず、HTMLでSwiperを使えるようにします。
https://github.com/nolimits4web/swiper/releases
から、swper(今回は swiper-4.4.6.zip)をダウンロードします。
ダウンロードしたswiper-2.7.6.zipを解凍して、swiper.min.cssとswiper.min.jsを取り出しまて、自分のサイトにアップロードします。
<HEAD></HEAD>の間に
<link rel=”stylesheet” href=”アップロードしたフォルダ/swiper.min.css”>
<BODY></BODY>の間の</BODY>の直前に
<script src=”アップロードしたフォルダ/swiper.min.js”>
</script>
を記載します。この部分がちょっと判りにくかったのでメモしておきます。

とりあえずアップロードしたswiper.min.jsとswiper.mini.cssは使わないで、
https://cdnjs.cloudflare.com/ajax/libs/Swiper/4.3.3/css/swiper.min.css
https://cdnjs.cloudflare.com/ajax/libs/Swiper/4.3.3/js/swiper.min.js
にリンクして動作させることにしました。

ここまで準備出来たら、後は https://garigaricode.com/swiper/ を参考に
Swiperのオプション設定(Javascript)の内容を
<script src=”アップロードしたフォルダ/swiper.min.js”>の下に
<script>    </script>に囲んで記入します。
この位置関係が重要です。
俊は

<script>
var mySwiper = new Swiper(‘.swiper-container’, {
loop: true,
navigation: {
nextEl: ‘.swiper-button-next’,
prevEl: ‘.swiper-button-prev’
},
pagination: {
el: ‘.swiper-pagination’,
type: ‘bullets’,
clickable: true
}
});
</script>

を選びました。

HTML内には表示したい場所に

<!– Swiper START –>
<div class=”swiper-container”>
<!– メイン表示部分 –>
<div class=”swiper-wrapper”>
<!– 各スライド –>
<div class=”swiper-slide”>Slide 1</div>
<div class=”swiper-slide”>Slide 2</div>
<div class=”swiper-slide”>Slide 3</div>
<div class=”swiper-slide”>Slide 4</div>
</div>
<div class=”swiper-button-prev”></div>
<div class=”swiper-button-next”></div>
<div class=”swiper-pagination”></div>
</div>
<!– Swiper END –>

を記入します。
<div class=”swiper-slide”>Slide 1</div>
のSlide 1部分は各自で表示したいものに変更します。
画像の場合は
<div class=”swiper-slide”><IMG src=”abare2.jpg” border=”0″></div>
みたいな感じです。

<div class=”swiper-button-prev”></div>
<div class=”swiper-button-next”></div>
は次のページ、前のページに移動するためのボタンで
<div class=”swiper-pagination”></div>
は何ページ目かを表示するためのものです。

2019年4月13日

実際に、動作させてみたのですが、自分のサイトのファイルでも無事動作しました。

https://kimassi.net/hudousan/1/kodate1.php

PHPで工夫が必要なのは、<div class=”swiper-slide”>Slide 1</div>で画像の登録数を確認し登録数に従って記述の数を調整すところかなと思います。
IF文でデータが無ければ、<!– メイン表示部分 –>の処理を止めるという処理でうまくいけば楽なんですけど。
最終的にはカラムにデータがあれば表示するという処理を、10回繰り返す方法を採用しました。

<!DOCTYPE html>
<html lang=”ja”>
<head>
<META name=”keywords” content=”金沢市,石川県,不動産,戸建て,中古”>
<META name=”description”content=”金沢の激安の中古住宅を紹介しています。”>
<META charset=”UTF-8″>
<STYLE>
<!–
.gyou{
line-height: 18pt ;
}
–>
</STYLE>
<STYLE>
<!–
body, th, td{
font-size: 95%;

// 600px以降から、100pxごとに1px大きくなる
@media (min-width: 600px) {
font-size: calc(112.5% + 4 * (100vw – 600px) / 400)
}

// 1,000px以上は、22pxに
@media (min-width: 1000px) {
font-size: calc(137.5%)
}
}

–>
</STYLE>
<STYLE>
<!–

@media(min-width: 600px){p.resizeimage3{
margin-top: 0px;margin-bottom: 0px;width: 720px;
}
}
p.resizeimage3 img{
width: 100%;
}

body,html{
max-width:800px;
margin-right: auto;
margin-left : auto;
}

–>
</style>

<link rel=”stylesheet” href=”https://kimassi.net/hudousan/swiper.min.css”>

<meta name=”viewport” content=”width=device-width,initial-scale=1″>
<TITLE>物件1  :金沢観光情報 【 きまっし金沢 】</TITLE>
</HEAD>
<BODY bgcolor=”#ffffff”>
<CENTER>
<TABLE>
<TBODY>
<TR>
<TD><A href=”https://kimassi.net/” target=”_top”><IMG src=”https://kimassi.net/kimassitoplogo.gif” alt=”金沢観光情報 【 きまっし金沢 】” width=”120″ border=”0″></A></TD>
<TD align=”left” valign=”middle”><H1 style=”font-size:18px; margin:0px;”><FONT color=”#cc0000″>物件1    </FONT></h1></TD>
</TR>
</TBODY>
</TABLE>
<BR>
</center>
<CENTER>
<TABLE class=”gyou”>
<TBODY>
<TR>
<TD ><FONT color=”#000000″>金沢近郊の激安(500万円以下)の中古の戸建てです。<BR>画像の横の矢印をクリックすると他の画像が見れます。</FONT><BR></TD>
</TR>
</TBODY>
</TABLE>

<?php
try {
$dsn=’mysql:host=127.0.0.1;dbname=kimassi_kodate’;
$db = new PDO($dsn, ‘kimassi_kodate’, ‘********’);
} catch (PDOException $e) {
echo ‘DB接続エラー: ‘ . $e->getMessage();
}
?>

<?php
$where=”no=1″;
?>

<BR>

</CENTER>

<CENTER>

<!– Swiper START –>
<div class=”swiper-container”>
<!– メイン表示部分 –>
<div class=”swiper-wrapper”>

<?php
$stmt = $db->query(”
SELECT *
FROM gekiyasukodate
WHERE $where
“);
$result = $stmt->fetch();

$price=number_format($result[‘kakaku’]);
if (empty($result[‘gazou2’])==false){
//<!– 各スライド –>;
echo “<div class=\”swiper-slide\”><p class=\”resizeimage3\”><IMG src=\””.$result[‘gazou2’].”\” border=\”0\”></P></div>\n”;}
if (empty($result[‘gazou3’])==false){
echo “<div class=\”swiper-slide\”><p class=\”resizeimage3\”><IMG src=\””.$result[‘gazou3’].”\” border=\”0\”></P></div>\n”;}
if (empty($result[‘gazou4’])==false){
echo “<div class=\”swiper-slide\”><p class=\”resizeimage3\”><IMG src=\””.$result[‘gazou4’].”\” border=\”0\”></P></div>\n”;}
if (empty($result[‘gazou5’])==false){
echo “<div class=\”swiper-slide\”><p class=\”resizeimage3\”><IMG src=\””.$result[‘gazou5’].”\” border=\”0\”></P></div>\n”;}
if (empty($result[‘gazou6’])==false){
echo “<div class=\”swiper-slide\”><p class=\”resizeimage3\”><IMG src=\””.$result[‘gazou6’].”\” border=\”0\”></P></div>\n”;}
if (empty($result[‘gazou7’])==false){
echo “<div class=\”swiper-slide\”><p class=\”resizeimage3\”><IMG src=\””.$result[‘gazou7’].”\” border=\”0\”></P></div>\n”;}
if (empty($result[‘gazou8’])==false){
echo “<div class=\”swiper-slide\”><p class=\”resizeimage3\”><IMG src=\””.$result[‘gazou8’].”\” border=\”0\”></P></div>\n”;}
if (empty($result[‘gazou9’])==false){
echo “<div class=\”swiper-slide\”><p class=\”resizeimage3\”><IMG src=\””.$result[‘gazou9’].”\” border=\”0\”></P></div>\n”;}
if (empty($result[‘gazou10’])==false){
echo “<div class=\”swiper-slide\”><p class=\”resizeimage3\”><IMG src=\””.$result[‘gazou10’].”\” border=\”0\”></P></div>\n”;}
?>
</div>
<div class=”swiper-button-prev”></div>
<div class=”swiper-button-next”></div>
<div class=”swiper-pagination”></div>
</div>
<!– Swiper END –>

<?php

echo “<table bgcolor=\”#fbe48c\”>\n”;

echo “<tr>\n”;
echo “<td bgcolor=\”#ffffff\” class=\”gyou2\” valign=\”top\”><span style=\”color: #ff0000;\”><strong>価格 $price 円</strong></span><BR>{$result[‘tiiki’]}{$result[‘tyoumei’]}
<A href=\”{$result[‘map’]}\” target=\”_blank\”>地図を見る</a> <BR>
土地面積 {$result[‘totimenseki’]}㎡ 建物面積 {$result[‘tatemonomenseki’]}㎡ <BR>築年数 {$result[‘tikunensuu’]}年  間取 {$result[‘madori’]}
駐車 {$result[‘tyuusya’]}<BR>
セットバック {$result[‘setback’]}   再建築の可否 {$result[‘saikentiku’]}<BR>
<span style=\”color: #ff0000;\”>{$result[‘bikou1’]}<BR>
{$result[‘bikou2’]}</span> <BR>
媒介種別 {$result[‘sennin’]}  登録日 {$result[‘date’]}</td>\n”;
echo “</tr>\n”;
echo “</table>\n”;

?>
</center>
<script src=”https://kimassi.net/hudousan/swiper.min.js”>
</script>
<script>
var mySwiper = new Swiper(‘.swiper-container’, {
loop: true,
navigation: {
nextEl: ‘.swiper-button-next’,
prevEl: ‘.swiper-button-prev’
},
pagination: {
el: ‘.swiper-pagination’,
type: ‘bullets’,
clickable: true
}
});
</script>

</BODY>
</HTML>

後は掲示板を設置と入会登録(さすがに高額な住宅を掲載するのに登録なしというのは具合悪い)のファイルは必要かな?
掲示板の投稿があった時に投稿者にもメールするようなシステムが良いかなと思います。

 

PHPで検索表示できるページにトライ

2019年3月25日

PHPでのプログラムも慣れてきたので、次は条件を設定してデータを表示できるページを作ろうかなと思っています。
商品を探すときに、いくらからいくらの範囲で、どういう条件のものを安い順に一覧表示してクリックしたら詳細情報を得られるというようなページってよく見かけますよね。

これをマスターすると、ほぼどんなホームページでも作成できるようになります。

とりあえず、激安の戸建ての家をテーマに作ってみようと思います。
業者に頼らなくても、家を処分したい人が無料で掲載できるようにすれば面白いかなと思います。

データベースの項目はno,id,date,tiiki,tyoumei,tikunensuu,tyuusya,map,setback,saikentiku,bikou1,bikou2,totimenseki,tatemonomenseki,madori,sennin,mail,namae,kakaku,gazou1,gazou2,gazou3,gazou4,gazou5,gazou6,gazou7,gazou8,gazou9,gazou10
検索対象はtiiki,tikunensuu,kakaku,tiiki2
表示順はdate,kakaku
一覧表示はdate,tiiki.tyoumei,tikunensuu,saikentiku,bikou2,totimenseki,tatemonomennseki,kakaku,madori,gazou1,new
だいたい、こういう感じかな。

2019年3月30日

XAMPP上のデータベースを作成してみました。画像ってデータベースに登録するには不向きなようです。画像へのアドレスを登録して画像は別にアップロードするようです。

2019年3月31日

とりあえずデータベースから読み込んで、画像を1つと築年数と価格を表で表示するPHPを作ってみました。
¥は画面上は\になって表示されますがエディターでcopy&pasteは問題なくできます。

<?php
try {
$pdo = new PDO(‘mysql:dbname=gekiyasukodate;host=127.0.0.1;charset=utf8’, ‘root’, ”);
} catch (PDOException $e) {
echo ‘DB接続エラー: ‘ . $e->getMessage();
}
?>

<?php

echo “<table bgcolor=\”#fbe48c\”>\n”;
$stmt =$pdo->query(“SELECT * FROM gekiyasukodate”);
$result = $stmt->fetchAll(PDO::FETCH_ASSOC);
foreach ($result as $results) {

$price=number_format($results[‘kakaku’]);

echo “<tr>\n”;
echo “<td bgcolor=\”#ffffff\” ><p class=\”resizeimage2\”><IMG src=\”{$results[‘gazou1’]}\” border=\”0\”></p></td>\n”;
echo “<td bgcolor=\”#ffffff\” class=\”gyou2\”>築年数 {$results[‘tikunensuu’]}年<BR>価格 $price 円</td>\n”;
echo “</tr>\n”;
}
echo “</table>\n”;

?>

2019年4月1日

1ページに5件のデータの表示にして、その以上のデータは次のページで表示しようと思ったのですが、なかなかできません。
ネットで調べて、試してみたのですが、なかなか正常に動作しませんでしたが、なんとか正常に動作するプログラムを見つけました。

https://manablog.org/php-pagination/

を参考に、とりあえず該当するデータを5件ずつ表示する事ができました。まだまだ改良が必要です。

<?php
try {
$pdo = new PDO(‘mysql:dbname=gekiyasukodate;host=127.0.0.1;charset=utf8’, ‘root’, ”);
} catch (PDOException $e) {
echo ‘DB接続エラー: ‘ . $e->getMessage();
}
?>

<?php

// GETで現在のページ数を取得する(未入力の場合は1を挿入)
if (isset($_GET[‘page’])) {
$page = (int)$_GET[‘page’];
} else {
$page = 1;
}

// スタートのポジションを計算する
if ($page > 1) {
// 例:2ページ目の場合は、『(2 × 5) – 5 = 5』
$start = ($page * 5) – 5;
} else {
$start = 0;
}

echo “<table bgcolor=\”#fbe48c\”>\n”;
// postsテーブルから5件のデータを取得する
$stml = $pdo->prepare(”
SELECT *
FROM gekiyasukodate
ORDER BY kakaku ASC
LIMIT {$start}, 5
“);
$stml->execute();
foreach ($stml as $results) {

$price=number_format($results[‘kakaku’]);

echo “<tr>\n”;
echo “<td bgcolor=\”#ffffff\” ><p class=\”resizeimage2\”><IMG src=\”{$results[‘gazou1’]}\” border=\”0\”></p></td>\n”;
echo “<td bgcolor=\”#ffffff\” class=\”gyou2\”>築年数 {$results[‘tikunensuu’]}年<BR>価格 $price 円</td>\n”;
echo “</tr>\n”;
}
echo “</table>\n”;

// postsテーブルのデータ件数を取得する
$page_num = $pdo->prepare(”
SELECT COUNT(*) id
FROM gekiyasukodate
“);
$page_num->execute();
$page_num = $page_num->fetchColumn();

// ページネーションの数を取得する
$pagination = ceil($page_num / 5);

?>

<?php for ($x=1; $x <= $pagination ; $x++) { ?>
<a href=”?page=<?php echo $x ?>”><?php echo $x; ?></a>
<?php } // End of for ?>

PHPのプログラムでエラー表示の際に、行数が表示されるのですが、実際のエディターでの行数とずれるので、不都合だったのですが、原因はエディターで2行に渡る文が実際には1行である場合があって、それが原因だと気づきました。
エディターの1行で表示できる文字数を最大にして解決しました。
秀丸の場合は、表示—-折り返し—-最大 でOKです。

2019年4月2日

ページへのリンクで現在表示されているページへのリンクを外して現在のページが判るようにしました。

// postsテーブルのデータ件数を取得する
$page_num = $pdo->prepare(”
SELECT COUNT(*) id
FROM gekiyasukodate
“);
$page_num->execute();
$page_num = $page_num->fetchColumn();

// ページネーションの数を取得する
$pagination = ceil($page_num / 5);

?>

<?php for ($x=1; $x <= $pagination ; $x++) {
if ($x <> $page ){
?>
<a href=”?page=<?php echo $x ?>”><?php echo $x; ?></a>
<?php
} else {echo $x;}?>
<?php }// End of for ?>

2019年4月5日

チェックボックス、ラジオボタンで条件を設定して、選択条件に従って検索するページを出力するPHPを作ろうと試行錯誤しています。
例えば、データから金沢と野々市の物件を価格の安い順に表示するような感じです。

チェックボックス、ラジオボタンの表示ができるのですが、選択した条件をデータとして取得するところが全く分かりません。結構し選べたのですが、分かりません。
それと複数の条件を1つの「送信する」でデータを取得する方法が判りませんでした。
これで3日間悩みました。

結論として、チェックボックス、プルダウン、ラジオボタンの使い方って、PHPでなくて、HTMLのformの勉強が必要だったのでした。ホームページは長年作っているけど、スタイルシートとformは避けていたので気が付きませんでした。
それと1つのフォームに複数のチェックボックスやプルダウン、ラジオボタンを入れて、まとめて送信する事も可能だとわかりました。

formではmethod= はgetかpostのどちらかを使い、action= では選択したデータを使って改めて表示しなおす場合は、今作動しているphpファイル(というかそのphpファイル自身)の名前を記入すれば良いようです。
(hudousan.phpというファイルなら<form method=”get” action=”hudousan.php”>)

option value= で選択したデータ(<option value=”kakaku”>ならkakaku)は、method=”get” の場合、<select name=”example1″>なら$_GET[‘example1’]で取り出せます。
こういう基本的な事を教えてくれる資料ってなかなか見つからなくて本当に苦労しました。
とりあえず、プルダウンで表示順を選択して表示する事ができるようになりました。

<?php
try {
$pdo = new PDO(‘mysql:dbname=gekiyasukodate;host=127.0.0.1;charset=utf8’, ‘root’, ”);
} catch (PDOException $e) {
echo ‘DB接続エラー: ‘ . $e->getMessage();
}
?>

<?php
function h($var) // HTMLでのエスケープ処理をする関数
{
if (is_array($var)) {
return array_map(‘h’, $var);
} else {
return htmlspecialchars($var, ENT_QUOTES, ‘UTF-8’);
}
}
// 表示する順番を設定 デフォルトは価格順
if (isset($_GET[‘example1’])) {
$example1=h($_GET[‘example1′]);
}
else { $example1=’kakaku’;}
?>

// 選択した条件を基に、現在のページを再読み込み
<form method=”get” action=”hudousan.php”>
<p>掲載順</p>
<select name=”example1″>
<option value=”kakaku”>物件の安い順</option>
<option value=”date”>登録が新しい順</option>
</select>
<p><input type=”submit” value=”送信する”></p>
</form>

<?php
echo “<table bgcolor=\”#fbe48c\”>\n”;
$stml = $pdo->prepare(”
SELECT *
FROM gekiyasukodate
ORDER BY $example1 ASC
“);
$stml->execute();
$result = $stml->fetchAll(PDO::FETCH_ASSOC);

foreach ($result as $results) {
$price=number_format($results[‘kakaku’]);// 数字を3桁ごとに,を入れて表示
echo “<tr>\n”;
echo “<td bgcolor=\”#ffffff\” ><p class=\”resizeimage2\”><IMG src=\”{$results[‘gazou1’]}\” border=\”0\”></p></td>\n”;
echo “<td bgcolor=\”#ffffff\” class=\”gyou2\”>築年数 {$results[‘tikunensuu’]}年<BR>価格 $price 円</td>\n”;
echo “</tr>\n”;
}
echo “</table>\n”;

でもチェックボックスで複数の条件を選択する方法がわかりません。

2019年4月6日

チェックボックスで複数の条件選択して、その選択条件に従って検索表示するPHPが動作しました。これだけで1日以上かかりました。
<input type=”checkbox” name=”example[]” value=”金沢市”>金沢市
<input type=”checkbox” name=”example[]” value=”野々市”>野々市
のようにして受け入れ画面を設置します。
example[] と ”野々市”>野々市 は各自が選びます。
example[]は配列なので[]は必須です。
<input type=”submit” value=”送信する”> でデータを送るのはプルダウンと同様です。

プルダウンの条件とチェックボックスで複数の条件選択の両方を一緒に条件を送るのは下記のような感じです。

 

<form method=”get” action=”hudousan.php”>
<p>掲載順</p>
<select name=”example1″>
<option value=”kakaku”>物件の安い順</option>
<option value=”date”>登録が新しい順</option>
</select>

<p>複数選択可</p>

<input type=”checkbox” name=”example[]” value=”金沢市”>金沢市
<input type=”checkbox” name=”example[]” value=”野々市”>野々市
<input type=”checkbox” name=”example[]” value=”白山市”>白山市
<input type=”checkbox” name=”example[]” value=”川北町”>川北町
<input type=”checkbox” name=”example[]” value=”内灘”>内灘
<input type=”checkbox” name=”example[]” value=”津幡町”>津幡町

<p><input type=”submit” value=”送信する”></p>
</form>

このページはhudousan.phpなのでaction=”hudousan.php”というのは自らのページを読み直すということになります。

最も重要なポイントは、1つの項目(カラム)で複数のデータを対象に検索する書式を把握する事でした。
例えば、tiikiという項目(カラム)で金沢市と白山市と川北町というデータを対象に検索する場合は、SELECT文の条件設定で WHERE  tiiki IN (“金沢市,白山市,川北町)   という書式が必要という事です。
tiiki IN (“金沢市,白山市,川北町)  の部分の文字列を取得するために 変数を設定します。ここでは$where にしました。
<form method=”get” action=”hudousan.php”>
<input type=”checkbox” name=”example[]” value=”金沢市”>金沢市
で入力したので、そのデータを受け取るには $_GET[‘example’] を使います。
つまり method=”get” と name=”example[]” の部分が受け取る配列名を決めているようです。

$where=”tiiki IN (“;
if (isset($_GET[‘example’])) {
foreach ($_GET[‘example’] as $value) {
$where=$where.”‘”.$value.”‘,”;
}
}

配列 $_GET[‘example’]  を 変数$whereに加えて、 $_GET[‘example’] の前に「 ‘ 」を後ろに「 ‘ 」と「 , 」を加えるという処理です。
$whereの文末が「 , 」 になるので、下記で、文末の「 , 」を削除して「 ) 」を加えます。

$where=substr($where, 0, -1).”)”;

SELECT文の条件設定の部分は

WHERE $where

になります。
なお条件設定して表示するので、表示のデータ数も減るのでページネーションの部分の変更も必要になりました。

$page_num = $pdo->prepare(”
SELECT COUNT(*) id
FROM gekiyasukodate
“);
$page_num->execute();
$page_num = $page_num->fetchColumn();

を下記に変更しました。

$page_num = $pdo->prepare(”
SELECT COUNT(*)
FROM gekiyasukodate
where $where
“);
$page_num->execute();
$page_num = $page_num->fetchColumn();

これでPHPで検索表示できるページの基本的な手法は理解できたのだと思います。

2019年4月7日

テーブル内の画像の上下部に余白ができるので、スタイルシートの

<STYLE>
<!–
@media(min-width: 600px){p.resizeimage2{
width: 240px;
}
}
p.resizeimage2 img{
width: 100%;
}
–>
</style>

を下記に書き換えました。

<STYLE>
<!–
@media(min-width: 600px){p.resizeimage2{
margin-top: 0px;margin-bottom: 0px;width: 240px;
}
}
p.resizeimage2 img{
width: 100%;
}
–>
</style>

2ページ目を見る時に、設定した条件がリセットされて、初期条件の2ページが表示され、設定した条件の2ページ目が見れなくなっていました。
2ページ目に飛ぶリンクは

<a href=”?page=<?php echo $x ?>”><?php echo $x; ?></a>

になっていますが、現状のページのアドレスを取得して、それを基に2ページ目のアドレスを指定するプログラムに変更しました。ばっちり動作しました。

<a href=”<?php echo $_SERVER[‘REQUEST_URI’]?> &page=<?php echo $x ?>”><?php echo $x; ?></a>

今まで、XAMPP上で動作させていたのですが、ある程度、動作するようになったので、オンラインで動作させる事にしました。
データベースのアドレスやデータベース名、テーブル名を変更してアップロードしたのですが、データベースのデータが表示されません。
プログラムを簡略化してもダメです。

$stml = $pdo->prepare(“SELECT * FROM gekiyasukodate”);

の部分が、XAMPPでは動作するけどオンラインでは動作しないようです。

$stml = $db->prepare(“SELECT * FROM gekiyasukodate”);

に変更すると動作しました。

https://kimassi.net/hudousan/hudousan.php

2019年4月8日

チェックボックス、ラジオボタンで条件を設定して、選択条件に従って中古戸建ての激安物件を検索一覧表示するページに必要項目をすべて表示できるように作り変えました。
詳細ページへのリンクも挿入しました。
詳細ページを作れば、とりあえずは基本的な処理はできます。
詳細ページの画像はスライドできてクリックで拡大できるといいかな。
投稿者の会員登録のページと投稿者のデータ入力のページや物件ごとの掲示板も設置しようと思います。かなり本格的なシステムになりそうです。

XAMPPが動作しない

2019年1月1日

新年に入って、時間に余裕が出来たので、PHPの勉強を始めました。

2019年1月3日

本を読んでいて、ちょっと理解しにくいところがあって、実際に動作させたくなって、パソコン上で動作できるXAMPPを利用する事にしました。
https://webkaru.net/php/setup/

Apacheの起動をしてみました。
でも、XAMPPのApacheで使うPort 80が他で使われていてApacheの起動ができません。

https://php1st.com/946
を参考にコマンドプロントでnetstat -nao を動作してローカルアドレスの数字が80のPIDを調べると4でした。
タスクマネージャーの詳細を確認するとSystem (NT Kemel & System)になっていました。

http://lovee7.blog.fc2.com/blog-entry-35.html
を参考に、[コントロールパネル] → [プログラム] → [プログラムと機能] → [Windowsの機能の有効化または無効化]で「Windowsの機能」ダイアログを表示させます。
「インターネット インフォメーション サービス」の項目を開いて、「World Wide Web サービス」のチェックを外しました。

XAMPPを管理者として実行(アイコンを右クリックで管理者として実行)する。
Apacheが起動しました。
Attempting to start Apache service.
が表示されましたが、それ以降進みません。
https://lightning2014.ensyutsubu.com/blog/post-6335/
を参考にして
XAMPP Control Panelで「Apache」の左側についたチェックを押すと×マークになります。
これでApacheの起動するようになりました。 ここまでの道は長かったです。
結局、最初にXAMPPを使わないでApacheが動作しなかった原因も、Port 80が他で使われていた事が原因だったようです。

c:/xampp/htdocs/ に動作するPHPファイル(例えば test.php)を設置してあれば
XAMPP Control PanelでApacheとMySQLをStartさせて
http://localhost/test.php
でtest.phpを動作させることができます。

2019年1月4日

実際にPHPのファイルを動作させてみましたが、日本語は文字化けしました。
c:/xampp/php/ のphp.iniを書き換えると解決するということなんですが、
PHPの絵本では、文字コードEUC-JPにすると書いてあったので、その通りにしても解決しなく
本が古いので、新しい環境(Windows10)に合わせたほうが良いのかなと思って
https://techacademy.jp/magazine/2412 を参考に
文字コードUTF-8にして保存してみたのですが、やっぱり解決しません。

2019年1月5日

結果的には文字コードUTF-8にするのが正解だったのですが、PHPのファイルを作る際にも、UTF-8で入力しなければいけなかったのです。
https://hombre-nuevo.com/programming/%E3%80%90php%E3%80%91%E6%96%87%E5%AD%97%E5%8C%96%E3%81%91%E5%AF%BE%E7%AD%96%E3%81%AE%E3%81%9F%E3%82%81php%E3%82%92%E6%97%A5%E6%9C%AC%E8%AA%9E%E5%8C%96%E3%80%90xampp%E3%80%91/
が参考になりました。

これで、やっと日本語を使ったPHPのファイルをパソコン上で動作させる環境が整いました。
これだけの事で、これほど苦労させられるなんて、先が思いやられます。

次はサーバー上で動作できるように設定です。
サーバーでの設定の変更は、サーバーごとに違うんだと思いますが、自分が利用しているサーバーcoreserverの場合は、coreserverにログインして、サイト設定でPHPのバージョンをphp72に変更です。

早速、XAMPP上で動作したphpファイルをFTPでアップロードして、属性を全部実行可(755)に設定し動作を試してみました。
無事動作しました。やったね!

2019年3月24日

PHPのプログラムの製作に成功し、XAMPP 上のPHPで動作させる必要性に迫られたので、主に使うパソコンすべてにXAMPP 上でPHPを動作する環境を設置する事にしました。

さっそくデスクトップの自作パソコンにXAMPPをインストールしたのですが、動作しません。
「or reconfigure Apache and the Control Panel to listen on a different port」というエラーです。

前回同様
[コントロールパネル] → [プログラム] → [プログラムと機能] → [Windowsの機能の有効化または無効化]で「Windowsの機能」ダイアログを表示させます。
「インターネット インフォメーション サービス」の項目を開いて、「World Wide Web サービス」のチェックを外しました。

XAMPPを管理者として実行(アイコンを右クリックで管理者として実行)する。
XAMPP Control Panelで「Apache」の左側についたチェックを押すと×マークになります。
startボタンをクリックすると、許可画面が表示されるので許可するとApacheが起動しました。
XAMPP Control Panel右上部のConfigをクリックして、Autostart of modulesのApacheにチェックを入れてSaveすると自動起動します。
Start Control Panel MinimizedにチェックしてSaveするとXAMPP Control Panelが表示することなく起動します。

次はPHPのインストールです。
前にダウンロードしてあったphp-7.2.13-Win32-VC15-X64 でインストールします。
展開したフォルダの名前をphpに変更してc:¥phpになるように配置し、phpフォルダの直下にある「php.ini-production」ファイルをコピーし、「php.ini」というファイル名に変更しました。

これでPHPがXAMPPで動作するようになりました。

残りもう1台も同じ設定で動作するようになりました。

ついでに、Windows7のAOA150(液晶サイズ:8.9インチ CPU:Atom N270/1.6GHz/1コア メモリ容量:1GB)にもインストールしました。
特に設定を変えることなく、すんなり動作しました。
PHPの処理も問題なくできました。
寝室用に使おうと思います。

中国からの送料っていくら?

2019年3月14日

ちょっと前に、カナショクの自動洗車を利用したのですが、ドアについての注意書きはあったのだけど、アンテナについての注意書きは他のところに小さくしか書いてなかったので、大丈夫かなあと思いながら、一番低い位置にしておけばいいのかなと思って、そのまま利用したんです。

そしたら、洗車の装置が元に戻る時、熱風でアンテナがぼよんぼよん上下に振れだして、唖然としてる内にボキっと折れちゃいました。
普段、無人なのですが、その時にたまたま係員がいてアンテナを折られたと言うと、アンテナの破損は利用者の責任で対応できないと言うんです。
今まで知らなかったのですが、自分のアンテナは外れる種類のものだったようです。

最近は自動車でラジオを聴くことは無く、ミュージックプレイヤーの音源をFMトランスミッターで飛ばしていたのでアンテナは不要なのですが、万が一の時には必要になるかもしれないので交換部品を探すことにしました。

それでamazonで調べたら、送料込み345円というのがあったのです。アンテナは結構長いので送料だけでも、かなりするんではないかと思います。
本当に届くのかなと思って注文してみました。
2月27日に注文して配達予定は3月11日までになっていました。
結果的に届いたのは今日だったのですが、ちゃんと届きました。

中国からWish郵という運送業者によって運送されていました。
簡易包装でしたが、40cm以上で重さは50g弱でした。ちなみに定形外郵便だと200円です。
送料がかからない前提で考えても、345円は凄いです。利益はどこからでているのでしょうか?

2019年3月19日

純正品より、少し感度が悪いかなと思いますが、充分に使えます。

2019年3月22日

せめてAmazonに商品レビューだけでもして貢献してあげようかなと思ったのですが、なぜか「申し訳ありませんが、この商品のレビューを受け付けることができません。 通常ではない投稿状況が確認された等いくつかの理由により、この商品のレビュー投稿は制限されています」と表示されてしまいました。

自分のメールアドレスからのスパムメール

2019年2月11日

自分のメールアドレスからスパムメールが送られてきました。
ちょっと気味が悪いのでネットで調べてみました。
Return-Pathの項目が同一のメールアドレスでなければ問題ないという事でしたがReturn-Pathも自分のメールアドレスでした。
ちなみに、そのスパムメールの主なデータは下記の通りです。
(Mozilla Thunderbird の場合は表示—-ヘッダー—すべて にすると表示されます)

差出人
kimassi@spacelan.ne.jp

Return-Path
kimassi@spacelan.ne.jp

最初の時間のReceived
from 39342E3137382E3230312E313534.XNGG4.SBWZQ.yrwoomocefinydcftn.icu (154-201-178-94.pool.ukrtel.net [94.178.201.154]) by chdom02.cm02.cloud-mail.jp (3.11g) with ESMTP id x1ADZjb9019275 for <kimassi@spacelan.ne.jp>; Sun, 10 Feb 2019 22:35:46 +0900 (JST)

内容は以上の通りです。

悪い日本人のために申し訳ありません。
あなたのメールアカウントをハッキングしました。
私はあなたのコンピューターをハッキングした。
私はあなたがポルノを見て見る。
私はあなたのウェブカメラで自慰行為を記録した。
あなたは私に(100000円)を支払わなければなりません。
あなたは48時間があります。
あなたが払っていない場合、私はあなたの隣人とあなたの家族や同僚にビデオを送信します。
あなたはbitcoinで支払う必要があります。
私のbitcoinアドレス:
1JacuT532ozUUtoTHHuXadZrR1yDnmu32K
あなたはbitcoinを購入する方法をgoogleできます。
あなたは48時間で支払っていない場合、私はあなたの連絡先にビデオを送信します。
あなたは非常に特別なポルノの味があります!
将来的には安全に保管してください。

Return-Pathも自分のメールアドレスだったのが気になったので、金沢ケーブルテレビに問い合わせしました。
16時間たちましたが返答はありません。

2019年2月12日

メールで問い合わせして30時間たったけど、金沢ケーブルテレビからは何の返答もありません。

2019年2月14日

相変わらず、返答がありません。
金沢ケーブルテレビのインフォメーションへの問い合わせに先がけて、その前日に前回問い合わせた時に返信があったサポートのメールアドレスにもメール送ったのですが、両方とも返信がありません。

前回は、自分のサイトの掲示板への自分の投稿が『IPアドレスが「逆引き出来ないホスト」のため投稿が拒否される』というトラブルがあって、対応してもらったのです。完全に金沢ケーブルテレビ側のミスでした。

2019年2月15日

結局、金沢ケーブルテレビのインフォメーションからもサポートからも全く返答がありませんでした。
金沢ケーブルテレビはお奨めしません。トラブルも多いしね・・・

2019年3月7日

日経ビジネスの記事で、似たような話が記事になっていました。
ポルノのウェブサイトにマルウェア(ウイルスなど悪意のあるソフトウェア)を置き、ポルノを視聴しているデバイス画面をキャプチャした映像と、デバイスのカメラで撮ったポルノ鑑賞中の使用者の映像を取得したうえ、デバイスから知人の連絡先の一覧も入手したと脅迫。「570ドル(約6万3000円)が私たちの小さな秘密な公正の価格」との言葉とともに、2日間の期限と支払先のビットコインアドレスを示したという。

そのメールには、、被害者がメールサービスなどに使用しているパスワードが記載されているということです。

脅迫メールの送信主のビットコイン口座を追跡調査すると、昨年9月以降、世界で1000件程度の払い込みがあり、総額で約4300万円に上るという。

メールのパスワードなんて、他のサイトで登録するものではないのに、なんで漏れるのか不思議なのですが、よく考えたらメールを受け取れる端末を8台持っているのですが、スマートフォンのメールアプリはあまり有名でないものも試しに使っているので漏れる可能性が無いわけではないです。

それにしても、メールのパスワードが漏れてるかもしれないと相談しているのに、何の返事もアドバイスもしない金沢ケーブルテレビは通信業者の体を成していないです。

そもそもメールのパスワードって自分で簡単に変えられるのかなあ(笑!)

2019年3月11日

Аmazon を語ったスパムメールがきました。
「Аmazon を更新できませんでした。
これは、カードが期限切れになったか。請求先住所が変更されたなど、さまざまな理由で発生する可能性があります。アカウント情報の一部が誤っている故に、お客様のアカウントを維持するため Аmazon 情報を確認する必要・ェあります。今アカウントを確認できます。」
というような内容のメールです。
差出人のアドレスは account-update@amazon.co.jp です。
最初のReceivedは
from xjb (10.119.73.34.bc.googleusercontent.com [34.73.119.10]) by dkshared103.ssl-sys.jp (Postfix) with ESMTPSA id A62EE1B80405 for <kimassi@spacelan.ne.jp>; Sun, 10 Mar 2019 15:07:16 +0900 (JST)
になっています。
Return-Pathは
<apple-004@xinshijie666.info>
なので明らかにスパムメールです。

Аmazon 注文時の正規のメールは
差出人のアドレスはAmazon.co.jp” <auto-confirm@amazon.co.jp>
最初のReceivedは
from a25-11.smtp-out.us-west-2.amazonses.com (a25-11.smtp-out.us-west-2.amazonses.com [54.240.25.11]) by chdom01.cm02.cloud-mail.jp (3.11g) with ESMTP id x1R8KJ9F005427 for <kimassi@spacelan.ne.jp>; Wed, 27 Feb 2019 17:20:20 +0900 (JST)
になっています。
Return-Path:は
<20190227082016e51241a873ff40db9f713437c660p0fe@bounces.amazon.co.jp>
なので本物だと判断できます。