百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

PHP入门读书笔记(十六):WEB页面使用PHP

itomcoil 2025-01-08 14:38 22 浏览

Web表单主要用来在网页中发送数据到服务器,经过程序处理中,将用户所需要的信息再传递给客户端的浏览器上。这样就形成了一个浏览者和网站之间的一个互动。

一、表单的提交方式

<form name=’NAME’ method=”GET” action=”URL”>
...
</form>

GET 提交或者GET()方法是将表单内容附加在URL后面的发送。在地址栏上的将会显示”“URL+用户传递的数据”组成一个大URL。URL和表单元素直接使用逗号“?”隔开的。多个表单元素用“&”隔开,每个表单元素的格式是name=value。注意大URL的长度限制在1M字符以内,数据量太大数据将会被截断,从而导致意外的处理结果。

POST 提交或者POST()方法是将将表单的信息作为一个数据块发送到服务器,在浏览器的地址栏不显示提交的信息。提交方式有表单的method属性,默认是GET()方法。表单的action是指向处理该表单页面的URL(相对位置或者绝对位置)

二、表单元素

一个表单里面就是表单元素。表单元素主要有输入域标记(<input>)、选择域标记(<select>)、文字域标记(<textarea>)

1、输入域标记

<input type=”type” name=”name” />

由type属性控制输入域的类型,name是输入域的名称。

下面介绍几个type属性

text:文本框属性,可以指定value(默认值),name(文本框的名称),size(文本框的宽度),maxlength(文本框的最大输入值)

password:密码域。用户输入的字符被替换成“*”

file:文件域。文件上传的使用。

image:图像域。可以用在提交按钮位置上的图片,具有按钮的功能。

radio:单选按钮。相同 name 代表在同一组,只能选择一项,checked 属性用来设置默认选中。

checkbox:复选框。允许选择多个选择项,checked 属性用来设置默认选中。

submit:提交按钮。提交表单内容到服务器。

reset:重置和清除表单内容。

button:普通按钮。可以激发提交表单的动作,一般配合javascript脚本进行表单处理。

hidden:隐藏域。在表单中隐藏方式提交变量值。对于用户是不可见的。提交的时候会一起随其他表单发送。

2、选择域标记

<select name=”name” value=”value” size=”3”>
<option value=”1”> 选项1 </option>
<option value=”2”> 选项2 </option>
</select>

name表示选择域的名称,size表示列表的行数,value 表示选项值,multiple表示该列表可以选择多项。默认只能选择一项。select 表示默认被选中

3、文字域标记

<textarea name=”name” value=”value” rows=10 cols=10 warp=”value”>
...
</textarea>

name表示文字域的名称,cols表示文字域的列数,rows表示文字域的行数,value表示文字域的默认值。warp用户设定显示和送出时的换行方式。warp=”off” 表示不自动换行,warp=”hard” 表示自动硬回车换行,换行标记一同发送到服务器,输出的时候也会被换行。warp=”soft”表示自动软回车换行,换行标记不会被发送到服务器,输出时候仍然为一列。

三、PHP参数传递的常用方法

php参数传递常用的方法有:$_POST[]、$_GET[]、$_SESSION[],分别用户获取表单,URL与session变量的值。

1、$_POST[] 全局变量

可以获取到POST()方法提交过来的表单元素的值。

格式:$_POST[name]

name 为表单元素的name

<?php
//省略创建表单,文本框的name为username,method 是 POST
$username = $_POST[“username”];
?>

注意:在有些php版本中,可以直接$username就可以指定表单的值。这是可以通过设置php.ini的register_globals=ON/OFF。如果是ON,可以直接写成$username,反之则不可以。这里不建议设置为ON,推荐使用register_globals=OFF。

2、$_GET[] 全局变量

可以获取到GET()方法提交过来的表单元素的值。

格式:$_GET[name]

name 为表单元素的name

<?php
//省略创建表单,文本框的name为username ,method是 GET
$username = $_GET[“username”];
?>

不管是$_GET[]还是$_POST[]获取表单元素的值,表单元素的名称是区别字母大小写的。疏忽了大小写,程序允许有可能取不到值或者弹出错误的提示信息。

3、$_SESSION[] 变量

$_SESSION[] 可以获取表单元素的值。

格式:$_SESSION[name]

name为表单元素的name。

<?php
//省略创建表单,文本框的name为username
$username = $_SESSION[“username”];
?>

该方法获取到的变量值,保存之后任何页面都可以使用,这种方式很耗费系统资源,是要慎重使用的。

四、在WEB页面中嵌入PHP脚本

1、在html页面中添加php脚本

·web页面中随时添加<?php ... ?> 标记,这两个标记中间的文本都会被解释为php,标记之外的任何文本都将被认为是普通的html

2、对表单元素的value赋值

只需将所需要赋值的数据直接添加到value数据中。

<?php
$val = “123456”; //定义一个$val 的值
?>
<input type=”text” name=”username” value=”<?php echo $val; ?>” />

五、对URL传递的参数进行编码/解码

1、对URL传递的参数进行编码。

前面我们说道GET()方法提交的就是一个长URL,表单数据都在URL里。

如:http://url?username=admin&password=123456

很明显这样的传递会将参数暴露问题,所以必须对URL传递的参数进行编码。

语法格式:string urlencode(string str);

实现了字符串str的url编码。比如参数中带有空格,进行编码后空格会被换成%20。

 <a href="index.php?id=<?php echo urlencode("我是中文的字符串"); ?>"> 我是中文的字符串 </a>
浏览器地址栏:
http://localhost/index.php?id=%CE%D2%CA%C7%D6%D0%CE%C4%B5%C4%D7%D6%B7%FB%B4%AE
查看源代码:
<a href="index.php?id=%CE%D2%CA%C7%D6%D0%CE%C4%B5%C4%D7%D6%B7%FB%B4%AE"> 我是中文的字符串 </a>

2、对URL传递的参数进行解码

对已经URL编码过的字符串,在$_GET[]方法获取的时候则还需要进行解码才能知道原来的值。

语法格式:strIng urldecode(string str);

实现了字符串在URL编码后的str字符串进行解码。

 <a href="index.php?id=<?php echo urlencode("我是中文的字符串"); ?>"> 我是中文的字符串 </a>
 <?php
$str = $_GET["id"];
$str2 = urldecode($str);
echo "解码后Id:".$str2;
?>
浏览器地址栏:
http://localhost/index.php?id=%CE%D2%CA%C7%D6%D0%CE%C4%B5%C4%D7%D6%B7%FB%B4%AE
查看源代码:
<a href="index.php?id=%CE%D2%CA%C7%D6%D0%CE%C4%B5%C4%D7%D6%B7%FB%B4%AE"> 我是中文的字符串 </a>
页面输出:
我是中文的字符串
解码后Id:我是中文的字符串


明天我们来看看php和javascript的交互。

相关推荐

selenium(WEB自动化工具)

定义解释Selenium是一个用于Web应用程序测试的工具。Selenium测试直接运行在浏览器中,就像真正的用户在操作一样。支持的浏览器包括IE(7,8,9,10,11),MozillaF...

开发利器丨如何使用ELK设计微服务中的日志收集方案?

【摘要】微服务各个组件的相关实践会涉及到工具,本文将会介绍微服务日常开发的一些利器,这些工具帮助我们构建更加健壮的微服务系统,并帮助排查解决微服务系统中的问题与性能瓶颈等。我们将重点介绍微服务架构中...

高并发系统设计:应对每秒数万QPS的架构策略

当面试官问及"如何应对每秒几万QPS(QueriesPerSecond)"时,大概率是想知道你对高并发系统设计的理解有多少。本文将深入探讨从基础设施到应用层面的解决方案。01、理解...

2025 年每个 JavaScript 开发者都应该了解的功能

大家好,很高兴又见面了,我是"高级前端进阶",由我带着大家一起关注前端前沿、深入前端底层技术,大家一起进步,也欢迎大家关注、点赞、收藏、转发。1.Iteratorhelpers开发者...

JavaScript Array 对象

Array对象Array对象用于在变量中存储多个值:varcars=["Saab","Volvo","BMW"];第一个数组元素的索引值为0,第二个索引值为1,以此类推。更多有...

Gemini 2.5编程全球霸榜,谷歌重回AI王座,神秘模型曝光,奥特曼迎战

刚刚,Gemini2.5Pro编程登顶,6美元性价比碾压Claude3.7Sonnet。不仅如此,谷歌还暗藏着更强的编程模型Dragontail,这次是要彻底翻盘了。谷歌,彻底打了一场漂亮的翻...

动力节点最新JavaScript教程(高级篇),深入学习JavaScript

JavaScript是一种运行在浏览器中的解释型编程语言,它的解释器被称为JavaScript引擎,是浏览器的一部分,JavaScript广泛用于浏览器客户端编程,通常JavaScript脚本是通过嵌...

一文看懂Kiro,其 Spec工作流秒杀Cursor,可移植至Claude Code

当Cursor的“即兴编程”开始拖累项目质量,AWS新晋IDEKiro以Spec工作流打出“先规范后编码”的系统工程思维:需求-设计-任务三件套一次生成,文档与代码同步落地,复杂项目不...

「晚安·好梦」努力只能及格,拼命才能优秀

欢迎光临,浏览之前点击上面的音乐放松一下心情吧!喜欢的话给小编一个关注呀!Effortscanonlypass,anddesperatelycanbeexcellent.努力只能及格...

JavaScript 中 some 与 every 方法的区别是什么?

大家好,很高兴又见面了,我是姜茶的编程笔记,我们一起学习前端相关领域技术,共同进步,也欢迎大家关注、点赞、收藏、转发,您的支持是我不断创作的动力在JavaScript中,Array.protot...

10个高效的Python爬虫框架,你用过几个?

小型爬虫需求,requests库+bs4库就能解决;大型爬虫数据,尤其涉及异步抓取、内容管理及后续扩展等功能时,就需要用到爬虫框架了。下面介绍了10个爬虫框架,大家可以学习使用!1.Scrapysc...

12个高效的Python爬虫框架,你用过几个?

实现爬虫技术的编程环境有很多种,Java、Python、C++等都可以用来爬虫。但很多人选择Python来写爬虫,为什么呢?因为Python确实很适合做爬虫,丰富的第三方库十分强大,简单几行代码便可实...

pip3 install pyspider报错问题解决

运行如下命令报错:>>>pip3installpyspider观察上面的报错问题,需要安装pycurl。是到这个网址:http://www.lfd.uci.edu/~gohlke...

PySpider框架的使用

PysiderPysider是一个国人用Python编写的、带有强大的WebUI的网络爬虫系统,它支持多种数据库、任务监控、项目管理、结果查看、URL去重等强大的功能。安装pip3inst...

「机器学习」神经网络的激活函数、并通过python实现激活函数

神经网络的激活函数、并通过python实现whatis激活函数感知机的网络结构如下:左图中,偏置b没有被画出来,如果要表示出b,可以像右图那样做。用数学式来表示感知机:上面这个数学式子可以被改写:...