表单处理

服务器接收用户发过来的数据方式:

$_GET 接收用户以GET方式发过来的数据

$_POST 接收用户以POST方式发过来的数据

$_COOKIE 接收用户COOKIE

$_REQUEST 接收用户发过来的数据

htmlspecialchars() 实体化编码

文件包含:通过一些文件包含的函数将本地或者远程服务器中文件包含解析到当前服务器中,达到文件读取、代码利用、函数调用等目的

include "文件名 "==include("文件名")

include_once

去包含文件时,后者只需要包含一次即可,当找不到包含的文件,会警告(php warning),后续代码依然会执行

require

require_once

包含文件时,后者只需要包含一次即可,当找不到包含的文件时,会直接报错,后续代码不执行

包含过来文件中,只要文件中代码是标准格式的PHP代码就会被解析,如果里面内容不是PHP代码,就会把内容显示出来。包含文件的写法:可以是相对路径,也可以是绝对路径

注意:读文件时需要注意当前web服务的权限

copy good.png/b+shell.php/a bad.png(Windows 本地生成图片马)

good.png 是一个正常图片 /b 表示比特流文件

shell.php 这是木马文件或者含有php代码的文件

/a 表示ASCII文件 bad.png 这是生成的图片马

会话管理

会话:服务器和用户之间传输数据的方式或者途经,在通道传输数据之间需要建立通道,这个通道可理解为会话,在客户端通过cookie来管理会话,在服务器通过session来管理会话,cookie和session的介绍以及区别?前面已经讲过!!

cookie和session比较:

1、cookie是存放在用户的浏览器中,是服务端通返回包中set-cookie来设置,cookie表示用户的浏览器和服务器之间的会话状态,登录成功之后方可获取cookie数据,该数据一般具有时效性,失效之后需要用户重新去登录。有了cookie数据之后,用户的每次请求都会带上cookie,服务端会验证该cookie的合法性和时效性,cookie的发送需要遵循浏览器的同源策略。

2、session是存放在服务端,表示用户和服务器之间的会话状态,session和cookie是一一对应的,服务器也需要记住哪个用户登录了该站点,一般情况下,session以文件的形式保存在/tmp目录中,形式为:sess_XXXXX,此刻服务器给浏览器分配的cookie跟session一样,只要该cookie的值被修改过,那么服务器就会要求用户重新登录。

cookie的管理,首先需要服务器给用户分发cookie数据,setcookie(name,value,表达式,路径,域范围),后三者可不写,其中表达式 主要用来设置cookie的时效性。注意:setcookie需要写在HTML代码之前

服务器获取cookie:$_COOKIE["cookie的名字"] 注意:需要使用当前打开的浏览器去访问,不能换用其他浏览器。

删除cookie:setcookie("loginInfo","",time()-3600); 通过服务器去删除

session的管理,工作机制:为用户创建唯一的uid,在该uid的基础上存储变量,uid放在cookie或者通过URL去传输(相比较,后者不安全)

在HTML代码之前通过session_start()开启(就意味着在/tmp目录下会生成session文件,格式:sess_uid,uid是32位的),开启之后可以通过session[]数组存储某些变量

销毁session方式:unset()和session_start()一起使用

session_destory()和session_start()一起使用 注意慎用会清除所有的session数据

header() 向用户的浏览器发送HTTP报头

echo"<meta charset='utf-8'/>";

header("Content-Type:text/html;charset=utf-8"); //解决编码问题

header('location:http://www.hacke.com/index.php')

文件上传:通过代码实现上传文件的功能。

explode(标识,字符串),按照标识将字符串分割为数组

explode(".","test.te.png")==arrat("test","te","png")

end(数组)取出数组中最后一个值

in_array($fileEndName, $array) 在数组中匹配要找的内容,如果有,则返回true

move_uploaded_file(临时文件位置,目的位置),将临时文件拷贝到目标位置中

file_exists() 检测文件或者目录是否存在,如果存在,则返回true

文件管理:通过PHP代码进行文件的打开、关闭、读取、写入

fopen(打开文件的位置包含了文件路径和文件名,打开文件的方式)

r 以只读的方式去打开

r+ 读和写

w 只以写的方式打开,如果文件不存在,则创建文件

w+ 读和写,如果不存在,则创建

a 文件末尾追加,如文件不存在,则创建文件

a+ 读和追加,如文件不存在,则创建

fclose(打开的文件对应的句柄) 关闭打开的文件

fread(打开的文件对应的句柄,读取大小单位是字节) 读取指定大小的文件内容

feof() 检测是否到达了文件的末尾,如果没有到达文件的末尾,返回值是false

fgets() 读取单行数据内容,只有一个参数,如果需要将整个文档都读取出来,则需要使用feof+fgets循环读 while(!feof($file)){echo fgets($file)}

fgetc()读取单个字符数据

file() 将整个文档中数据读取到数组中,一行对应一个单元

file_get_contents() 将整个文档值班费的数据读取到字符串中

file_put_contents(文件名,数据) 写数据,如果文件名不存在,则创建文件

basename() 文件名 dirname()

copy(源文件,目标文件) 拷贝

unlink() unset() 删除文件

命令执行函数,通过php中某些函数去执行系统命令,和系统交互

常用的命令执行函数有:

system()

exec() 执行了但是没有返回值

shell_exec()

echo 'whoami';

passthru()等等

代码执行函数,使用PHP某些函数去执行字符串类型的PHP代码,注意:PHP代码

常用函数有:

eval()

assert() 代码中通;可以不要

preg_replace(/正则表达式/e,替换的字符。被替换的字符串),注意:如果执行代码解析功能

preg_replace("/test/e","system(net user)","test icq");

PHP表单处理、会话管理、文件上传、文件处理、执行函数(10.8 第十六天)的更多相关文章

  1. c# 模拟表单提交,post form 上传文件、大数据内容

    表单提交协议规定:要先将 HTTP 要求的 Content-Type 设为 multipart/form-data,而且要设定一个 boundary 参数,这个参数是由应用程序自行产生,它会用来识别每 ...

  2. c# 模拟表单提交,post form 上传文件、数据内容

    转自:https://www.cnblogs.com/DoNetCShap/p/10696277.html 表单提交协议规定:要先将 HTTP 要求的 Content-Type 设为 multipar ...

  3. 使用django表单,使网页添加上传文件,并分析文件。

    开发环境是: apache + python + django+ eclipse(开发环境) 欲达到目的: 在网页上,添加上传文件控件.然后读取csv文件,并分析csv文件. 操作步骤: django ...

  4. from表单实现无跳转上传文件,接收页面后台数据。

    本文基于我刚写的http://www.cnblogs.com/iwang5566/p/6287529.html进行了简单的扩展,实现页面无跳转表单数据提交,并接收后台返回的数据. 下载好,上一篇文章d ...

  5. from表单实现无跳转上传文件,接收页面后台数据

    实现无跳转发送表单数据.文件,并能接收后台返回的数据. 主要技术要点: 1.form表单添加target属性,指定一个iframme的name:form表单提交后在iframe内嵌窗口接受响应,主页面 ...

  6. WebLogic 任意文件上传远程代码执行_CVE-2018-2894漏洞复现

    WebLogic 任意文件上传远程代码执行_CVE-2018-2894漏洞复现 一.漏洞描述 Weblogic管理端未授权的两个页面存在任意上传getshell漏洞,可直接获取权限.Oracle 7月 ...

  7. 摒弃FORM表单上传图片,异步批量上传照片

    之前作图像处理一直在用form表单做图片数据传输, 个人感觉low到爆炸而且用户体验极差,现在介绍一个一部批量上传图片的小技巧,忘帮助他人的同时也警醒自己在代码的编写时不要只顾着方便,也要考虑代码的健 ...

  8. MVC文件上传文件限制

    最近想实现MVC中文件上传限制,总觉得有便利的方法,找了半天就找到加属性accept <input type="file" id="file" name= ...

  9. 【收集】JAVA多文件 上传文件接口代码 -兼容app

    原文:http://www.verydemo.com/demo_c143_i23854.html 我们在 multifile 中可以很容易的发现如何使用,这里就简单说说了,首先在页面上我们需要有这样几 ...

  10. ASP.NET Core WEB API 使用element-ui文件上传组件el-upload执行手动文件文件,并在文件上传后清空文件

    前言: 从开始学习Vue到使用element-ui-admin已经有将近快两年的时间了,在之前的开发中使用element-ui上传组件el-upload都是直接使用文件选取后立即选择上传,今天刚好做了 ...

随机推荐

  1. Ajax--XMLHttpRequest的使用

    1.创建XMLHttpRequest对象(实现方法不统一): --IE把XMLHttpRequest实现为一个ActiveX对象: --其他浏览器(Firefox.Chrome等)把它实现为一个本地的 ...

  2. 5.3 Nginx 动静分离

    Server 脚本片段 server { listen ; server_name ccserver1; #charset koi8-r; access_log logs/host.access.lo ...

  3. 说说我对SQL语句执行顺序的理解,以SQL Server为例

    有人说SQL语句难学,其实并不难!只要掌握了基本的语句执行顺序,用程序化的思维分析结构,再难的问题也会迎刃而解! 假设有如下表emp 现在要求 列出员工姓名(ename)中不含A的所有人按照部门编号( ...

  4. Docker + Maven + Docker-compose

    前言: docker:容器化管理 maven:支持docker-maven的插件,通过 mvn clean -Dmaven.test.skip package dockerfile:build 打包命 ...

  5. 5G时代能携号转网,你会提前换新手机吗?

    每一次网络制式的变革,总能引发业界和大众的强烈关注.毕竟网络制式的迭代,能为社会的方方面面带来极大嬗变.而5G时代即将开启,必然会出现更多弄潮儿,也会带来让人心动的美好生活.不过,鉴于5G本身的特殊性 ...

  6. python学习0day

    一开始学习python没有什么感觉,也没怎么用到,时间间隔大概有一年了开始重新拾起python,话说滋味不太好受,推荐大家学到就常常的练习,不要和小白一样,难受.... 推荐一个网站: 菜鸟教程 - ...

  7. Visual Studio中的“build”、“rebuild”、“clean”的区别

    区别 rebuild基本相当于clean+build build只针对修改过的文件进行编译,rebuild会对所有文件编译(无论是否修改). clean 删除中间和输出文件,中间文件是指一些生成应用的 ...

  8. 123.ModelForm的使用

    ModelForm 在我们的实例中,需要通过models.py中定义相关的模型字段,之后在forms.py中同样需要定义每个字段进行相应的验证,这样的话,我们会需要重复定义,这样的话,就相对比较麻烦, ...

  9. 从零开始学C++(1 变量和基本类型)

    接下来的几篇文章介绍C++的基础知识点. C++是一种静态数据类型语言,它的类型检查发生在编译时.因此,编译器必须知道程序中每一个变量对应的数据类型. 数据类型是程序的基础:它告诉我们数据的意义以及我 ...

  10. 《新标准C++程序设计》4.7-4.9(C++学习笔记17)

    一.重载类型强制转换运算符 在C++中,类型的名字(包括类的名字)本身也是一种运算符,即类型强制转换运算符.类型强制转换运算符是单目运算符,也可以被重载,但只能重载为成员函数,不能重载为全局函数.经过 ...