質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Bluetooth

Bluetoothとは短距離の間でデータを交換するための無線通信規格である。固定・モバイル両方のデバイスから、短波の電波送信を行うことで、高いセキュリティをもつパーソナルエリアネットワーク(PAN)を構築する。

PDO

PDO(PHP Data Objects)はPHPのデータベース抽象化レイヤーです。

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

Linux

Linuxは、Unixをベースにして開発されたオペレーティングシステムです。日本では「リナックス」と呼ばれています。 主にWebサーバやDNSサーバ、イントラネットなどのサーバ用OSとして利用されています。 上位500のスーパーコンピュータの90%以上はLinuxを使用しています。 携帯端末用のプラットフォームAndroidは、Linuxカーネル上に構築されています。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

1回答

1764閲覧

PHPでDBのmacaddressカラムからmacアドレスを取得しl2pingを打つ方法

2323

総合スコア5

Bluetooth

Bluetoothとは短距離の間でデータを交換するための無線通信規格である。固定・モバイル両方のデバイスから、短波の電波送信を行うことで、高いセキュリティをもつパーソナルエリアネットワーク(PAN)を構築する。

PDO

PDO(PHP Data Objects)はPHPのデータベース抽象化レイヤーです。

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

Linux

Linuxは、Unixをベースにして開発されたオペレーティングシステムです。日本では「リナックス」と呼ばれています。 主にWebサーバやDNSサーバ、イントラネットなどのサーバ用OSとして利用されています。 上位500のスーパーコンピュータの90%以上はLinuxを使用しています。 携帯端末用のプラットフォームAndroidは、Linuxカーネル上に構築されています。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

0グッド

0クリップ

投稿2021/11/03 14:17

### 前提・実現したいこと PHPでデータベース(MySQL)のusersテーブルにあるmacaddressカラムからmacアドレスを取得し そのmacアドレスに対してl2pingを一括で打つプログラムを作りたい。 この状態からどうすれば実現したいことを実現できるか知りたい。 ### 発生している問題・エラーメッセージ PHP Warning:Invalid argument supplied for foreach() in~on line 21となります。 一度他の書き方をしてエラー回避したけど結局1つしか結果が表示されなかった。

PHP

1<?php 2 //データベースに接続 3 $pdo=new PDO('mysql:dbname=xxxx;host=xxx.xxx.x.x;','xxxxx','xxxxx'); 4 //文字化け防止処理 5 $pdo->query('SET NAMES utf8;'); 6 //接続判定後に接続結果を表示 7 if(!$pdo){ 8 die('Sorry...DB not found.'); 9 }else{ 10 echo 'DBconnection is success!'; 11 } 12 $rows=""; 13 //usersテーブルのmacaddressカラムを取得 14 $sql='SELECT macaddress FROM users'; 15 //queryメソッドでmacaddressカラムを全抽出しstmtに格納 16 $stmt=$pdo->query($sql); 17 while($result=$stmt->fetch(PDO::FETCH_ASSOC)){ 18 $rows .= $result['macaddress']."<br>"; 19 } 20 echo '登録されているmacアドレスはこちらです:'.$rows; 21 foreach($rows as $row){ 22 exec("sudo l2ping -c 1".$row,$opt,$return_ver); 23 if($return_ver==0){ 24 echo '疎通成功'; 25 }else{ 26 echo '疎通失敗'; 27 } 28 } 29 //DBの接続を終了 30 unset($pdo); 31?>

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

データを長い文字列としてあつめているので foreach では使えないよ
っていってますね。
例えば

php

1 //usersテーブルのmacaddressカラムを取得 2 $sql = 'SELECT macaddress FROM users'; 3 //queryメソッドでmacaddressカラムを全抽出しstmtに格納 4 $stmt = $pdo->query($sql); 5 $rows = []; 6 while ($result=$stmt->fetch(PDO::FETCH_ASSOC)) { 7 $rows[] = $result['macaddress']; 8 } 9 echo '登録されているmacアドレスはこちらです:' . implode("<br>", $rows); 10 foreach ($rows as $row) { 11 exec("sudo l2ping -c 1".$row,$opt,$return_ver); 12 if ($return_ver==0) { 13 echo '疎通成功'; 14 } else { 15 echo '疎通失敗'; 16 } 17 }

投稿2021/11/03 20:44

takasima20

総合スコア7464

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問