多数大学生出来选择的工作和专业无关
首页 > 专业知识

PHP实现超简单的SSL加密解密方法

时间:2018-08-02 19:26:06 [来源]:郑州PHP培训学校

     PHP实现超简单的SSL加密解密方法

  本文实例讲述了PHP实现超简单的SSL加密解密、验证及签名的方法。分享给大家供大家参考,具体如下:
  1. sign签名代码:
  function sign($data) {
  //读取私钥文件
  $priKey = file_get_contents('key/rsa_private_key.pem');//转换为openssl密钥,必须是没有经过pkcs8转换的私钥$res = openssl_get_privatekey($priKey);
  //调用openssl内置签名方法,生成签名$sign
  openssl_sign($data, $sign, $res);
  //释放资源
  openssl_free_key($res);
  return $sign;
  }
  2. verify 验证代码:
  function verify($data, $sign) {
  //读取支付宝公钥文件
  $pubKey = file_get_contents('key/alipay_public_key.pem');//转换为openssl格式密钥
  $res = openssl_get_publickey($pubKey);
  //调用openssl内置方法验签,返回bool值
  $result = (bool)openssl_verify($data, $sign, $res);//释放资源
  openssl_free_key($res);
  return $result;
  }
  3. 解密代码
  function decrypt($content) {
  //读取商户私钥
  $priKey = file_get_contents('key/rsa_private_key.pem');//转换为openssl密钥,必须是没有经过pkcs8转换的私钥$res = openssl_get_privatekey($priKey);
  //声明明文字符串变量
  $result = '';
  //循环按照128位解密
  for($i = 0; $i < strlen($content)/128; $i++ ) {$data = substr($content, $i * 128, 128);
  //拆分开长度为128的字符串片段通过私钥进行解密,返回$decrypt解析后的明文openssl_private_decrypt($data, $decrypt, $res);//明文片段拼接
  $result .= $decrypt;
  }
  //释放资源
  openssl_free_key($res);
  //返回明文
  return $result;
  }
 
  PHP编程常用技巧四则有哪些
  1.配置PHP文件目录
  作为服务器端解释执行的脚本语言,PHP程序放置在某个服务器可以访问的目录下,一般可以通过修改Apache的httpd.conj进行配置,例如我们在该文件中的一句:
  Alias /test/ "d:brhpwebsitebrhp/" 那么在浏览器端输入:“http://localhost/test/+PHP文件名”就可以访问d:brhpwebsitebrhp/下的PHP文件了;可见该行不过是为存放PHP文件的目录起一个别名。
  其次,还可以通过指定DocumentRoot路径得到存放服务器文件的目录,在httpd.conj找到以下两行,其中的路径可以随意指定,你的PHP文件也可以放在该目录下,服务器同样可以运行它们,如“http://localhost/+PHP文件名”。
  一般的,将PHP文件放在同一个地方比较好,可以方便管理,而其他文件放在另外一个地方。
  DocumentRoot "C:/usr/bin/html/"
  2.服务器端目录的索引文件
  在httpd.conj中,有一行: DirectoryIndex index.html
  该行指定目录默认打开文件为index.html,当访问某个目录时,服务器就会自动查找index.html, 若果不存在,则显示目录中的所有文件列表,默认打开文件可以改为别的,如index.php3等等,但是也许我们有很多目录,无论是存放图片,文本等资料的,还是存放PHP文件或别的文件的目录,我们并不希望用户能看到目录中的文件列表,在httpd.conj 中指定了一个.htacess文件,该文件产生一个目录索引文件,例如我们用写字板建立一个.htacess文件:
  # .htacess #
  DirectoryIndex error_open.php
  再建立一个错误警告文件:
  # error_open.php #
  其中的error_open.php为权限错误警告文件,将此2文件放在所有保护目录下,当用户企图打开目录时,自动转向执行error_open.php,显示错误警告。
  3.目录删除巧实现
  我们知道,PHP4 for/win32中有个rename()函数可以支持对目录/文件进行重命名,如: rename( oldpath, newpath) // oldpath为文件或目录原来路径; // newpath为新定义路径;
  实现将 oldpath改名为 newpath。
  PHP4中没有删除目录/文件的函数,怎么作到删除呢?我们知道,php.ini中有一行用来完成HTTP上传操作的临时文件目录配置行: upload_tmp_dir= ;
  PHP4支持该临时目录的配置(PHP3不支持),当上载操作完成则自动清空临时目录,好了,用它我们可以巧妙的实现文件/目录的删除,比如设置: upload_tmp_dir="d:brhpwebsitebrhp/tmp/" ; 要删除某个目录 path,执行: tmp="d:brhpwebsitebrhp/tmp/;" rename( path, tmp) ?>;
  那么文件或目录 path改名为 tmp后, tmp目录下的所有文件/目录自动清除,就完成了删除操作。
  4.快速建立MySql数据库表
  PHP和MySql数据库达到了完美结合,在网页上,比如在论坛或书屋发表作品的新用户,我们要把他的言论信息在线写入数据库中,往往要在相应的数据库中为该用户新建一个数据表。win32下建立新的MySQL空数据库很简单,只要在“/mysql/data/”目录下建立一个文件夹,如:"/usrinfo/",就可以了。而向库中增添新表可通过以下程序实现:
  # connect.mysql--连接数据库 #
  connection = mysql_connect();
  mysql_select_db("usrinfo", connection);
  ?>;
  # make.php-- 建立如下结构的,以用户名为表名的数据表 #
  //调用connect.mysql
  require("connect.mysql");
  //检查以用户名为表名的数据表存在否? query="select count(*) from usrname";
  result=mysql_db_query( query);
  //不存在则创建,如存在就是老用户;
  if(! result)
  { mysql_query("
  create table usrname(
  id tinyint(6),
  title text,
  body longtext,
  dateof date;
  timeof time; )") or die(mysql_error());
  }
  //此处为向数据表插入新的数据部分
  ?>

上一篇:PHP常见错误的具体纠正方法

下一篇:php基础知识:函数基础知识