WeChat パブリック プラットフォーム メッセージ インターフェイスの開発例、近くの企業の地理的位置クエリ

高洛峰
リリース: 2017-03-31 14:50:28
オリジナル
3304 人が閲覧しました

1. ユーザーのアドレスと位置メッセージを取得します

ユーザーが位置を送信するときのメッセージと形式は次のとおりです

WeChat パブリック プラットフォーム メッセージ インターフェイスの開発例、近くの企業の地理的位置クエリ

バックエンド形式:

   1359036619  22.539968 113.954980 16  5837017832671832047 
ログイン後にコピー

XML 形式の説明


ToUserName 消息接收方微信号,一般为公众平台账号微信号 FromUserName 消息发送方微信号 CreateTime 消息创建时间 MsgType 消息类型,地理位置为location Location_X 地理位置纬度 Location_Y 地理位置经度 Scale 地图缩放大小 Label 地理位置信息 MsgId 消息ID号
ログイン後にコピー

2. 取得周辺エリア情報

Baidu Map Place API は、特定のエリアをクエリするために特定の種類の POI データを返すために使用されるシンプルな HTTP インターフェイスであり、単一の POI に対して詳細なクエリ サービスを提供します。ユーザーは C#、C++、Java などを使用できます。 HTTP リクエストを送信し、json、xml データを受信するための他の開発言語。

Place API は、地域検索 POI サービス、POI 詳細サービス、グループ購入情報検索サービス、および加盟店グループ購入詳細クエリを提供します。地域検索POIサービスでは、都市内検索、長方形検索、円形エリア検索の3つの地域検索方法を提供しています。

円形領域検索を使用して、近くの検索機能を実装します。

場所エリア検索POIサービスインターフェースは次のとおりです:

http://api.map.baidu.com/place/v2/search

2000 周辺探索半径、単位はメートル q(クエリ) は なし 中関村、ATM 、Baidu Building 検索キーワード、周辺機器 複数のキーワードの結合検索をサポートしており、最大 10 個のキーワード検索がサポートされています。例: 「銀行$ホテル」。 タグ いいえ なし 日本のバーベキュー/鉄板焼き、チャオワイストリート アイテムにタグを付けて、qと組み合わせて検索 出力 いいえ xml jsonまたはxml 出力形式はjsonまたはxmlです scope is 1 1、2 検索結果の詳細。値が 1 または空の場合は、基本情報が返され、値が 2 の場合は、取得した POI の詳細情報が返されます。 |並べ替え名:価格 |ソートルール:0 |価格セクション:100,200 sort_name: 並べ替えフィールド

パラメータ

必要ですか

デフォルト値

フォーマット例

意味

location

なし

38.76623,116.43213
lat <緯度> ,lng <経度>

|グルーポン:0

|discount:0

フィルター条件を取得します。スコープ値が 2 の場合、ソート用のフィルターを設定できます。

Industry_type: 業界タイプ
sort_rule: 並べ替えルール、値は次のとおりです: 0: 高い方から低い方へ、1: 低い方から高い方へ

; 価格セクション: 価格帯

groupon: 共同購入の有無。1 は共同購入があることを意味し、0 は共同購入がないことを意味します。 割引: 割引があるかどうか。1 は割引があることを意味し、0 は割引がないことを意味します。

page_size

10

10

范围记录数量,默认为10条记录,最大返回20条。多关键字检索时,返回的记录数为关键字个数*page_size。

page_num

0

0、1、2

分页页码,默认为0,0代表第一页,1代表第二页,以此类推。

ak

E4805d16520de693a3fe707cdc962045

用户的访问密钥,必填项。v2之前该属性为key。

sn

用户的权限签名。

timestamp

设置sn后该值必填。

调用举例如下:


http://api.map.baidu.com/place/v2/search?ak=MgBALVVeCd8THVBi6gPdvsvG&output=json&query=%E9%93%B6%E8%A1%8C&page_size=5&page_num=0&scope=2&location=39.915,116.404&radius=2000&filter=sort_name:distance
ログイン後にコピー

三、程序实现

百度地图类定义如下

class baiduMapClient { private $api_server_url; private $auth_params; public function __construct() { $this->api_server_url = "http://api.map.baidu.com/"; $this->auth_params = array(); $this->auth_params['key'] = "401f9a693dd267dd9a4661ec0895fb20"; $this->auth_params['output'] = "json"; } public function Geocoding_coordinate_address($location) { return $this->call("geocoder", array("location" => $location)); } //http://api.map.baidu.com/place/search?&query=眼镜&location=39.915,116.404&radius=3000&output=json&key=37492c0ee6f924cb5e934fa08c6b1676 public function Place_search($query, $location, $radius) { return $this->call("place/search", array("query" => $query, "location" => $location, "radius" => $radius)); } protected function call($method, $params = array()) { $headers = array( "User-Agent: Mozilla/5.0 (Windows NT 5.1; rv:14.0) Gecko/20100101 Firefox/14.0.1", "Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8", "Accept-Language: en-us,en;q=0.5", //"Accept-Encoding: gzip, deflate", "Referer: http://developer.baidu.com/" ); $params = array_merge($this->auth_params, $params); $url = $this->api_server_url . "$method?".http_build_query($params); if (DEBUG_MODE){echo "REQUEST: $url" . "\n";} $ch = curl_init(); curl_setopt($ch, CURLOPT_URL, $url); curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); //curl_setopt($ch, CURLOPT_HTTPHEADER, $headers); $data = curl_exec($ch); curl_close($ch); $result = null; if (!empty($data)){ if (DEBUG_MODE){ echo "RETURN: " . $data . "\n"; } $result = json_decode($data); } else{ echo "cURL Error:". curl_error($ch); } return $result; } }
ログイン後にコピー

获取附近的调用代码如下:

function catchEntitiesFromLocation($entity, $x, $y, $radius) { $mapObj = new baiduMapClient(); $search = $mapObj->Place_search($entity, $x.",".$y, $radius); $results = $search->results; for ($i = 0; $i < count($results); $i++) { $distance = getDistance($x, $y, $results[$i]->location->lat, $results[$i]->location->lng); $shopSortArrays[$distance] = array( "Title"=>"【".$results[$i]->name."】<".$distance."M>".$results[$i]->address.(isset($results[$i]->telephone)?" ".$results[$i]->telephone:""), "Description"=>"", "PicUrl"=>"", "Url"=>""); } ksort($shopSortArrays);//排序 $shopArray = array(); foreach ($shopSortArrays as $key => $value) { $shopArray[] = array( "title" => $value["Title"], "description" => $value["Description"], "pic" => $value["PicUrl"], "url" => $value["Url"], ); if (count($shopArray) > 6){break;} } return $shopArray; }
ログイン後にコピー

计算两坐标之间距离如下

function getDistance($lat_a, $lng_a, $lat_b, $lng_b) { //R是地球半径(米) $R = 6366000; $pk = doubleval(180 / 3.14169); $a1 = doubleval($lat_a / $pk); $a2 = doubleval($lng_a / $pk); $b1 = doubleval($lat_b / $pk); $b2 = doubleval($lng_b / $pk); $t1 = doubleval(cos($a1) * cos($a2) * cos($b1) * cos($b2)); $t2 = doubleval(cos($a1) * sin($a2) * cos($b1) * sin($b2)); $t3 = doubleval(sin($a1) * sin($b1)); $tt = doubleval(acos($t1 + $t2 + $t3)); return round($R * $tt); }
ログイン後にコピー

对于用户的坐标记录,我们使用数据库的方式来存储,

如果用户发送查询命令,则直接查询,

function searchUserLocation($userWxid) { Global $mysql_host; Global $mysql_host_s; Global $mysql_port; Global $mysql_user; Global $mysql_password; Global $mysql_database; //查询使用从库,支持SAE $mysql_table = "location"; $mysql_state = "SELECT * FROM ".$mysql_table." WHERE userWxid = \"".$userWxid."\""; $con = mysql_connect($mysql_host.':'.$mysql_port, $mysql_user, $mysql_password); if (!$con){ die('Could not connect: ' . mysql_error()); } mysql_query("SET NAMES 'UTF8'"); mysql_select_db($mysql_database, $con); $result = mysql_query($mysql_state); $location = array(); while($row = mysql_fetch_array($result)) { $location["x"] = $row["locationX"]; $location["y"] = $row["locationY"]; } mysql_close($con); if (isset($location["x"]) && $location["x"] != 0.0){ return $location; }else{ return "系统中没有你的地理位置信息,请先发送位置给我!您不用担心你的行踪被泄漏,因为你可以滑动地图,把别处的地址发送过来。"; } }
ログイン後にコピー

如果用户发了位置,则进行更新

function updateOrInsert($weixinid, $locationX, $locationY) { if (isset($_SERVER['HTTP_APPNAME'])){ $mysql_host = SAE_MYSQL_HOST_M; $mysql_host_s = SAE_MYSQL_HOST_S; //sae的从库 $mysql_port = SAE_MYSQL_PORT; $mysql_user = SAE_MYSQL_USER; $mysql_password = SAE_MYSQL_PASS; $mysql_database = SAE_MYSQL_DB; }else{ $mysql_host = "127.0.0.1"; $mysql_host_s = "127.0.0.1"; $mysql_port = "3306"; $mysql_user = "root"; $mysql_password = "root"; $mysql_database = "sae"; } $mysql_table = "location"; //INSERT INTO location VALUES("23s2s", 1122.2, 366.2) ON DUPLICATE KEY UPDATE locationX = 1122.2, locationY = 366.2; $mysql_state = "INSERT INTO ".$mysql_table." VALUES(\"".$weixinid."\", ".$locationX.", ".$locationY.") ON DUPLICATE KEY UPDATE locationX = ".$locationX.", locationY = ".$locationY.";"; var_dump($mysql_state); // $con = mysql_connect($mysql_host.':'.$mysql_port, $mysql_user, $mysql_password); if (!$con){ die('Could not connect: ' . mysql_error()); } mysql_query("SET NAMES 'UTF8'"); mysql_select_db($mysql_database, $con); $result = mysql_query($mysql_state); if ($result == true){ //return "你提交的位置为纬度:".$locationX.",经度:".$locationY."。\n现在可以发送“附近”加关键字的命令查询附近的目标,如“附近酒店”,“附近医院”。"; return "已经成功获取你的位置。您不用担心你的行踪被泄漏,因为你可以把千里之外的地址提交过来。\n现在可以发送“附近”加关键字的命令查询附近的目标,如“附近酒店”,“附近医院”。"; }else{ return "提交失败,请重试。如果一直出现这样的错误,请给我们留言。"; } }
ログイン後にコピー

对于用户发送的内容,先提取坐标,然后进行组合查询

WeChat パブリック プラットフォーム メッセージ インターフェイスの開発例、近くの企業の地理的位置クエリ

实现效果如下:

WeChat パブリック プラットフォーム メッセージ インターフェイスの開発例、近くの企業の地理的位置クエリWeChat パブリック プラットフォーム メッセージ インターフェイスの開発例、近くの企業の地理的位置クエリWeChat パブリック プラットフォーム メッセージ インターフェイスの開発例、近くの企業の地理的位置クエリ

以上がWeChat パブリック プラットフォーム メッセージ インターフェイスの開発例、近くの企業の地理的位置クエリの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!