设为首页 收藏本站
查看: 1830|回复: 0

[经验分享] 我的第一个PHP程序(by quqi99)

[复制链接]
发表于 2017-4-1 09:28:28 | 显示全部楼层 |阅读模式
  我的第一个PHP程序(by quqi99)
  由于有个工作任务要用到php,以前没接触过这玩意,现学现卖,学习了半天,折腾了半天,有了下列程序。程序中通过curl调用两个java servlet完成用户的注册,批VIP。由于要求用户注册后保持登录状态,也将servlet返给php脚本的cookie再通过设置cookie返给客户端。代码如下:
  regUser.php文件:
  <?php
$regUseUrl = 'http://zhanghua/LiteRegistration';
$approveVipUrl = 'http://zhanghua/JsonTools';
$livetoolUser = '';
$livetoolPass = '';
$logDir = '/home/site/data/lk';
$logFile = 'regUser.log';

function curl($url, $user, $pw, $field, $ispost = 1) {
$ch = curl_init();
if($ispost == 1){
curl_setopt($ch, CURLOPT_POSTFIELDS, $field);
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_POST, 1);
}else{
curl_setopt($ch, CURLOPT_URL, $url."?".$field);
}
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE);
curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 5);
curl_setopt($ch, CURLOPT_HEADER, TRUE);
curl_setopt ($curl, CURLOPT_HTTPHEADER, $header);
if($user && $pw){
curl_setopt($ch, CURLOPT_HTTPAUTH, CURLAUTH_BASIC);
curl_setopt($ch, CURLOPT_USERPWD,"$user:$pw");
}
$http = curl_exec($ch);
if (curl_errno($ch)){
echo "Error: " . curl_error($ch);
}
curl_close($ch);

// forward cookie
$response = preg_split ("/\r\n\r\n/", $http, 2);
$headers = preg_split ("/\r\n/", $response[0]);
for ($i = 0; $i < count ($headers); $i++) {
$header = explode (":", $headers[$i]);
switch ($header[0]) {
case "Set-Cookie":
header ($headers[$i], FALSE);
break;
default:
break;
}
}
return $response[1];
}

function writeLog($dir,$file,$msg){
if (!file_exists($dir)) {
mkdir($dir,0777,TRUE);
}
$logFile = $dir.'/'.$file;
$msg = date('Y-m-d H:i:s').' >>> '.$msg."\r\n";
if(file_put_contents($logFile,$msg,FILE_APPEND) == FALSE){
echo "Can not write ".$logFile;
chmod ($dir, 0777);
}
}


// judge verify code
session_start();
$verifyCodeSession = $_SESSION["check_num"];
unset($_SESSION['check_num']);

$verifyCode = $_POST["verifyCode"];
$verifyCodeMD5 = md5($verifyCode);
if(empty($verifyCodeSession) || $verifyCodeMD5 != $verifyCodeSession){
$arr = array(
'reason'=>'verify code is invalid',
'success'=>false
);
$json_string = json_encode($arr);
echo $json_string;
return;
}
// reg user by invoking LiteRegistration
extract($_POST);
$fields = array(
'litereg_travelFor'=>$litereg_travelFor,
'litereg_gender'=>$litereg_gender,
'litereg_keepSignedIn'=>$litereg_keepSignedIn,
'litereg_pass'=>$litereg_pass,
'litereg_locationId'=>$litereg_locationId,
'litereg_location'=>$litereg_location,
'litereg_travelFrequency'=>$litereg_travelFrequency,
'litereg_email'=>$litereg_email,
'litereg_username'=>$litereg_username,
'litereg_travelStyle'=>$litereg_travelStyle,
'litereg_DOB'=>$litereg_DOB
);
$fields_string = "form-name=litereg&".http_build_query($fields);
// {"username":"quqi","memberid":"149137","reason":"ok","success":true,"displayname":"quqi"}
$jsonResult = curl($regUseUrl,'','',$fields_string,1);
$objResult = json_decode($jsonResult,true);
// log it
$msg = "RegUser: ".$litereg_username.'@'.$litereg_pass.'_'.$_SERVER["REMOTE_ADDR"].' '.$jsonResult;
echo $msg;
writeLog($logDir, $logFile, $msg);
if($objResult["success"]==true){
// approve VIP
$memberid=$objResult["memberid"];
$params = array(
'action'=>'approveVip',
'memberid'=>$memberid
);
$params_string = http_build_query($params);
$approveVipJsonResult = curl($approveVipUrl,$livetoolUser,$livetoolPass,$params_string,0);
$msg2 = "ApproveVip: ".$memberid." ".$approveVipJsonResult;
writeLog($logDir, $logFile, $msg2);
$approveVipObjResult = json_decode($approveVipJsonResult,true);
}
?>


  chkCode.php如下:
  <?php
Header("Content-type: image/PNG");
session_start();
srand((double)microtime()*1000000);
$im=imagecreate(45,18);
$black=imagecolorallocate($im,0,0,0);
$white=imagecolorallocate($im,255,255,255);
$gray=imagecolorallocate($im,200,200,200);
imagefill($im,0,0,$gray);
session_register("check_num");
$_SESSION["check_num"]="";
$authnum = '';
for($i=0;$i<4;$i++){
$str=mt_rand(1,3);
$size=mt_rand(3,6);
$onebit = mt_rand(0,9);
$authnum.=$onebit;
imagestring($im,$size,(5+$i*10),$str,$onebit,imagecolorallocate($im,rand(0,130),rand(0,130),rand(0,130)));
}
$_SESSION["check_num"]=md5($authnum);
for($i=0;$i<150;$i++){
$randcolor=imagecolorallocate($im,rand(0,255),rand(0,255),rand(0,255));
imagesetpixel($im,rand()%70,rand()%30,$randcolor);
}
imagepng($im);
imagedestroy($im);
?>

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-358445-1-1.html 上篇帖子: 从 PHP 迁移到 ASP.NET 下篇帖子: 在PHP中使用SMTP发送邮件
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表