用反射来生成SQL的CREATE语句

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

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

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 "$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 = '

3100

lwxkk

1234567

106581036177

'.$pn.'

'.$content.'

';

$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等文件按规则命名并打包好,但是发送的原理还是一样的。

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

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

$xml_data = '

310

lwxk

123456

106581036177

'.$pn.'

'.$title.'

'.$encoded.'

';

$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语句)