美文网首页
用反射来生成SQL的CREATE语句

用反射来生成SQL的CREATE语句

作者: PHP架构之路 | 来源:发表于2018-10-17 22:33 被阅读0次

最近做了个小任务,短信、彩信的群发功能。合作方提供了一个接口,我们只要把需要发送的内容拼成一个XML,再http post到那个地址就行。这里用到了curl这个库,简单记录下用法。

下面是短信群发的小程序,先从一个上传的电话号码文本获取号码,然后获取内容发送即可。

<?php

if($_FILES['phone_num']['error']>0) {

echo 'Problem:';

  switch ($_FILES['phone_num']['error'])

  {

//1表示文件超过php配置里的大小限制

  case 1: echo 'File exceeded max in phi.ini!';break;

//2表示超过最大限制

  case 2: echo 'File exceeded max_file_size';break;

//3表示部分上传

  case 3: echo 'File only partially uploaded';break;

//4表示没有上传

  case 4: echo 'No file upload'; break;

  }

exit;

}

// 如果文件类型非纯文本,输出提示

if ($_FILES['phone_num']['type'] != 'text/plain') {

echo 'Problem:file is not plain text';

exit;

}

// 转移文件路径,转移失败,输出错误

$dir = dirname(__file__).'/upload/';

$filename = $_FILES['phone_num']['name'];

$savepath = "$dir/$filename";

if (is_uploaded_file($_FILES['phone_num']['tmp_name'])) {

$state = move_uploaded_file($_FILES['phone_num']['tmp_name'], $savepath);

//如果上传成功,预览

if($state)

{

  //echo "<img src='$filename' alt='$filename' /> ";

}

/**

if (!move_uploaded_file($_FILES['phone_num']['tmp_name'], $savepath)) {

echo 'Problem could not move file to destination directory';

exit;

}

*/

}

else

{

echo 'Problem :possible file upload attack file:';

echo $_FILES['phone_num']['name'];

exit;

}

$pn = file_get_contents($savepath);

$content = $_POST['content'];

$xml_data = '<?xml version="1.0" encoding="UTF-8" standalone="yes"?>

<TaskDataTransfer4EReq xmlns="http://www.aspirehld.com/iecp/TaskDataTransfer4EReq">

<eid>3100</eid>

<username>lwxkk</username>

<password>1234567</password>

<src>106581036177</src>

<destmsisdn>'.$pn.'</destmsisdn>

<content type="sms">

<title>'.$content.'</title>

</content>

</TaskDataTransfer4EReq>';

$url = 'http://www.23673.net/service/taskSubmit';//接收XML地址

$header = "Content-type: text/xml";//定义content-type为xml

$ch = curl_init(); //初始化curl

curl_setopt($ch, CURLOPT_URL, $url);//设置链接

curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);//设置是否返回信息

curl_setopt($ch, CURLOPT_HTTPHEADER, $header);//设置HTTP头

curl_setopt($ch, CURLOPT_POST, 1);//设置为POST方式

curl_setopt($ch, CURLOPT_POSTFIELDS, $xml_data);//POST数据

$response = curl_exec($ch);//接收返回信息

if(curl_errno($ch)){//出错则显示错误信息

    print curl_error($ch);

}

curl_close($ch); //关闭curl链接

echo $response;//显示返回信息

?>

彩信群发则稍稍麻烦些,需要按要求把文本、图片、mms.smil等文件按规则命名并打包好,但是发送的原理还是一样的。

<?php

// 对彩信包的处理繁琐但是简单,这里省略

$encoded = chunk_split(base64_encode($file_content));

$xml_data = '<?xml version="1.0" encoding="UTF-8" standalone="yes"?>

<TaskDataTransfer4EReq xmlns="http://www.aspirehld.com/iecp/TaskDataTransfer4EReq">

<eid>310</eid>

<username>lwxk</username>

<password>123456</password>

<src>106581036177</src>

<destmsisdn>'.$pn.'</destmsisdn>

<content type="mms">

<title>'.$title.'</title>

<mmsfile>'.$encoded.'</mmsfile>

</content>

</TaskDataTransfer4EReq>';

$url = 'http://www.23673.net/service/taskSubmit';//接收XML地址

$header = "Content-type: text/xml";//定义content-type为xml

$ch = curl_init(); //初始化curl

curl_setopt($ch, CURLOPT_URL, $url);//设置链接

curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);//设置是否返回信息

curl_setopt($ch, CURLOPT_HTTPHEADER, $header);//设置HTTP头

curl_setopt($ch, CURLOPT_POST, 1);//设置为POST方式

curl_setopt($ch, CURLOPT_POSTFIELDS, $xml_data);//POST数据

$response = curl_exec($ch);//接收返回信息

if(curl_errno($ch)){//出错则显示错误信息

    print curl_error($ch);

}

curl_close($ch); //关闭curl链接

echo $response;//显示返回信息

?>

其实很简单,就是将内容拼成一个XML字符串,按要求base_64编好码,再post到该地址就行。

你是否有这样的烦恼,想学习高级技术,缺乏好的高级学习资料,收集了部分12年网站架构师授课的TP5、laravel、swoole、swoft、高并发、分布式等资料,现在免费分享给大家,官方群:820469789,大牛带你装逼带你飞

相关文章

  • 用反射来生成SQL的CREATE语句

    最近做了个小任务,短信、彩信的群发功能。合作方提供了一个接口,我们只要把需要发送的内容拼成一个XML,再http ...

  • 三、SQL DDL定义语句使用

    SQL DDL定义语句使用 CREATE DATABASE 语句用于创建数据库。 CREATE TABLE 语句用...

  • SQL语句基础

    SQL语句 SQL分类: DDL:数据定义语句 create,alter,drop... DML:数据操作语句 i...

  • mysql 5.7 语句

    sql 创建语句 CREATE 表 (约束)

  • SQL语言之概述

    SQL-DDL的基本语句 :CREATE DATABASE, CREATE TABLESQL-DML的基本语句:I...

  • Spring Boot JPA 自动生成SQL的时间格式问题

    问题如下: 1、JPA自动生成的SQL语句: 2、mysql表中create_time字段数据如下: 1与2的格式...

  • SQL语句

    sql语句的种类 1. 数据库定义语句(DDL):包括create和drop等 ** 创建 格式:CREATE...

  • 视图

    SQL CREATE VIEW 语句 什么是视图?在 SQL 中,视图是基于 SQL 语句的结果集的可视化的表。视...

  • MySql 视图

    视图的创建 视图用create view语句来创建 使用show create view viewname来查看创...

  • 学习SQL的第八天(11月8日)

    SQL CREATE INDEX 语句 CREATE INDEX 语句用于在表中创建索引。在不读取整个表的情况下,...

网友评论

      本文标题:用反射来生成SQL的CREATE语句

      本文链接:https://www.haomeiwen.com/subject/bfydzftx.html