php数据库链接
Php超全局变量
GET 和 POST 都创建一个数组(例如 array( key1 => value1, key2 => value2, key3 => value3, ...))。此数组包含键/值对,其中 键是表单控件的名称,值是来自用户的输入数据。
GET 和 POST 都被视为 _GET 美元和 _POST 美元。这些是超全局, 这意味着无论范围如何,它们始终都可以访问 - 您可以从任何功能访问它们, 类或文件,而无需执行任何特殊操作。
$_GET 是通过 URL 参数传递给当前脚本的变量数组。
$_POST 是通过 HTTP POST 方法传递给当前脚本的变量数组。
$_get
使用 GET 方法从表单发送的信息对每个人都可见(所有 变量名称和值显示在 URL 中)。GET 对 要发送的信息。限制约为 2000 个字符。然而 由于变量显示在 URL 中,因此可以将 页。这在某些情况下可能很有用。
GET 可用于发送非敏感数据。
注意:永远不要使用GET来发送密码或其他敏感信息
$_post
使用 POST 方法从表单发送的信息对其他人是不可见的(所有名称/值都嵌入在 HTTP 请求的正文中),并且 对要发送的信息量没有限制。
此外,POST还支持高级功能,例如支持多部分 将文件上传到服务器时的二进制输入。
但是,由于变量未显示在 URL 中,因此无法为页面添加书签
创建一张名为table.php的php表格 一张名为table.html的表格
观察以下代码
- Html基本表单部分
<html>
<body>
<form action="welcome.php" method="POST">
Name: <input type="text" name="name"><br>
E-mail: <input type="text" name="email"><br>
<input type="submit">
</form> //action部分定义了post应该发送到哪里去
</body> //name部分中type定义了发送数据的类型为text文本
</html> //name中的 name定义了在php脚本中post应当得到的键
- php部分
<html>
<body>
Welcome <?php echo $_POST["name"]; ?><br>
Your email address is: <?php echo $_POST["email"]; ?>
</body> //在这里 post全局变量接受来自table.html发送来的txt文本数据
</html> //并且通过html将其标记在屏幕之上
重要函数部分
mysqli_fetch_array()
函数在 MySQLi 扩展中用于从结果集中获取一行作为关联数组、数字索引数组、或两者兼有的混合数组。它的返回值类型取决于传递给函数的参数:
//利用这个函数,我们可以判断存储的用户是否已经存在
- MYSQLI_ASSOC: 当设置为该常量时,会返回关联数组,键是列名。
- MYSQLI_NUM: 数字索引数组,键是从 0 开始的整数,对应的是查询结果的列顺序。
- MYSQLI_BOTH: 这样的话,将同时返回关联数组和数字索引数组,每行数据都有两个版本。
如果没指定模式,默认返回类型取决于结果集的第一行,后续行将以最初选择的模式继续获取。
Die()
是 PHP 中的一个内置函数,它用于立即停止脚本执行并返回给客户端指定的消息。当你在代码中遇到严重错误或者需要中断整个程序流程的情况时,可以使用 die() 函数输出错误信息,同时终止当前页面的加载,不会执行后续的代码。
这个函数通常与错误消息一起使用,比如当数据库连接失败、文件找不到等异常情况发生时,你可以捕获到错误并使用 die() 来快速显示错误信息并结束脚本,以便于开发者调试。
Query
HP中,query通常是指对数据库的操作。它涉及到使用SQL查询语言从数据表中获取、修改或删除信息。PHP提供了一些内置函数,如mysqli_query()、PDO::query()等,用于连接到数据库并执行查询操作
->运算符
->是一个运算符,也被称为"箭头"或"指向"运算符,主要用于访问对象属性和方法。当你有一个对象,并想要通过该对象调用其内部的属性或方法时,会使用这个符号。
->在这里的作用相当于“点”运算符.,但在访问对象属性时,它明确表示你是在操作一个对象而不是一个变量。如果尝试用.来访问属性,比如echo person.name,那么就会报错,因为person只是一个变量名,不是对象实例。
class Person {
public $name;
public function greet() {
return "Hello, my name is " . $this->name;
}
}
$person = new Person();
$person->name = "Alice"; 将Alice放入类所对应的属性中去
echo $person->name; // 输出 "Alice"
echo $person->greet(); // 输出 "Hello, my name is Alice"
MySQLi_connect($servsername,$username,$password,$dbnamr)
MySQLi_connect是php建立与MySQL数据连接的函数
Try
在许多编程语言中,try 关键字用于开始一个异常处理块。当一段可能会抛出错误或异常的代码块需要被执行时,通常将其包裹在 try 块内。如果在这段代码执行期间发生异常,那么控制权会被立即转移到与之匹配的 catch 块中,catch 块负责捕获并处理这个异常,避免程序崩溃。
try:
# 可能会抛出异常的代码
result = int(input("请输入一个整数: "))
except ValueError:
# 处理 ValueError 异常
print("输入的不是有效的整数!")
except
except 是编程中用于异常处理的关键字之一,通常与 try 配合使用。当你预期某段代码可能会抛出异常时,可以在 try 块之后编写一个或多个 except 子句。每个 except 子句会捕获特定类型的异常,并提供一个代码块来处理这个异常情况,而不是让程序因为异常而终止运行。
try {
// 可能会抛出异常的代码块
throw new TypeError("Some error");
} catch (TypeError $e) {
// 捕获并处理 TypeError 类型的异常
echo "Caught a TypeError: " . $e->getMessage();
} except (Exception $e) { // 抛出所有不是 TypeError 的异常
// 这里不会捕获到 TypeError,因为已经明确在前一个 catch 中处理了
echo "Caught an Exception: " . $e->getMessage();
}
Pdo
PDO 是 PHP 数据对象(PHP Data Objects)的缩写,是一个 PHP 扩展,用于提供一致的方式来访问多种数据库,包括 MySQL、PostgreSQL、SQLite 等。PDO 提供了一种安全、高效和面向对象的方式来操作数据库,它支持预处理语句(PreparedStatement),这有助于防止 SQL 注入攻击,并可以提高性能。
$conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);语句,这行代码的作用是将PDO的错误模式设置为异常模式,使用异常模式的好处在于,你可以通过try-catch语句块来捕获这些异常
try {
// 假设$dsn, $username, $password已经正确定义
$conn = new PDO($dsn, $username, $password);
// 设置错误模式为异常
$conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
// 执行一些数据库操作
} catch (PDOException $e) {
// 捕获异常并处理
echo "数据库错误:" . $e->getMessage();
// 可以根据需要记录日志等
}
Exec()
exec() 函数是一个非常有用的函数,它允许你在PHP脚本中执行一个外部程序,并且可以将外部程序的输出传递给PHP变量。这个函数在需要调用系统命令或执行外部脚本时特别有用。
escapeshellcmd()
escapeshellcmd() 函数是 PHP 中用于转义 shell 命令字符串中可能会被解释为 shell 命令的特殊字符的函数。当你需要将用户输入或其他不可信的数据作为 shell 命令的一部分时,这个函数特别有用,因为它可以帮助防止命令注入攻击
<?php
$userInput = $_GET['cmd']; // 假设这是用户输入的命令名
$safeCommand = escapeshellcmd($userInput); // 转义特殊字符
exec("ls -l " . $safeCommand); // 现在安全多了
?>
escapeshellcmd() 主要用于转义那些可能会被 shell 解释的特殊字符,但它不会验证命令的合法性或确保命令是安全的。
MySQ创建数据库
<?php
$servername = "localhost";
$username = "root";
$password = "202019利用变量存储基本信息
// Create connection
$conn = new mysqli($servername, $username, $password); 建立存储MySQL连接
// Check connection
if ($conn->connect_error) {
die("Connection failed: " . $conn->connect_error);
} $conn 对象的一个属性nnect_error,如果不为空,则链接出错
// Create database
$sql = "CREATE DATABASE myDB";
if ($conn->query($sql) === TRUE) {
echo "Database created successfully";
} else {
//查询sql中是否存在通过$sql命令创建的数据库
echo "Error creating database: " . $conn->error;
}
$conn->close();
?>
//利用PDO创建数据库
<?php
$servername=”localhost”;
$username=”root”;
$password=”202019”;
Try {
//尝试一个可能会出错的程序
$conn=newPDO(“mysql:host=$servername”,$username,$password);
//set th PDO error mode to exception
$conn->setAttribute(PDD::ATTR_ERRORMODE, PDD::ERRMOD_EXCEPTION);
$sql=”crate database mytest”;
$conn->exec($sql); //允许利用外部的程序
Echo “Database created successfully<br>”;}
Catch(PDDException $e){ //将错误信息放入$e
Echo $sql . “<br>”.$e->getMessage();
}
?>
}
相关文章:
php数据库链接
Php超全局变量 GET 和 POST 都创建一个数组(例如 array( key1 > value1, key2 > value2, key3 > value3, ...))。此数组包含键/值对,其中 键是表单控件的名称,…...
python+vue3+onlyoffice在线文档系统实战20240726笔记,左侧菜单实现和最近文档基本实现
解决右侧高度过高的问题 解决方案:去掉右侧顶部和底部。 实现左侧菜单 最近文档,纯粹文档 我的文档,既包括文件夹也包括文件 共享文档,别人分享给我的 基本实现代码: 渲染效果: 简单优化 设置默认菜…...
vue中的nexttrick
Vue.js 是一个用于构建用户界面的渐进式框架,它允许开发者通过声明式的数据绑定来构建网页应用。在 Vue 中,nextTick 是一个非常重要的 API,它用于延迟回调的执行,直到下次 DOM 更新循环之后。 为什么使用 nextTick? …...
【BUG】已解决:ModuleNotFoundError: No module named ‘requests‘
ModuleNotFoundError: No module named ‘requests‘ 目录 ModuleNotFoundError: No module named ‘requests‘ 【常见模块错误】 【解决方案】 欢迎来到英杰社区https://bbs.csdn.net/topics/617804998 欢迎来到我的主页,我是博主英杰,211科班出身&a…...
深入理解JS中的发布订阅模式和观察者模式
发布/订阅模式(Publish/Subscribe)和观察者模式(Observer Pattern)在概念上非常相似,都是用于实现对象之间的松耦合通信。尽管它们在实现细节和使用场景上有所不同,但核心思想是相通的。 观察者模式 直接通信:在观察者模式中,观察者(Observer)直接订阅主题(Subject…...
网站IPv6支持率怎么检测?
在当今数字化的时代,IPv6的推广和应用已经成为网络发展的重要趋势。IPv6拥有更大的地址空间、更高的安全性和更好的性能,对于满足日益增长的网络需求至关重要。对于网站所有者和管理员来说,了解其网站对IPv6的支持率是评估网站性能和兼容性的…...
react中简单的配置路由
1.安装react-router-dom npm install react-router-dom 2.新建文件 src下新建page文件夹,该文件夹下新建login和index文件夹用于存放登录页面和首页,再在对应文件夹下分别新建入口文件index.js; src下新建router文件用于存放路由配置文件…...
RocketMQ消息短暂而又精彩的一生(荣耀典藏版)
目录 前言 一、核心概念 二、消息诞生与发送 2.1.路由表 2.2.队列的选择 2.3.其它特殊情况处理 2.3.1.发送异常处理 2.3.2.消息过大的处理 三、消息存储 3.1.如何保证高性能读写 3.1.1.传统IO读写方式 3.2零拷贝 3.2.1.mmap() 3.2.2sendfile() 3.2.3.CommitLog …...
Linux中的文件操作
linux中exec*为加载器,可以将程序加载到内存。 main()函数也是函数,也要被调用,也要被传参 故在一个程序中exec*系列的函数先被执行 程序替换中execve是系统调用,其他的都是封装。 进程程序替换 1.创建子进程的目的࿱…...
[排序]hoare快速排序
今天我们继续来讲排序部分,顾名思义,快速排序是一种特别高效的排序方法,在C语言中qsort函数,底层便是用快排所实现的,快排适用于各个项目中,特别的实用,下面我们就由浅入深的全面刨析快速排序。…...
freertos的学习cubemx版
HAL 库的freertos 1 实时 2 任务->线程 3 移植 CMSIS_V2 V1版本 NVIC配置全部是抢占优先级 第四组 抢占级别有 0-15 编码规则, 变量名 :类型前缀, c - char S - int16_t L - int32_t U - unsigned Uc - uint8_t Us - uint…...
PyQt 信号与槽功能
PyQt 信号与槽功能 基本概念:在 PyQt 中,信号(Signal)与槽(Slot)是一种用于对象之间通信的机制。信号可以由一个对象发出,而槽是用于接收信号并执行相应操作的函数。 信号 信号是在 PyQt 的类…...
navicat premium安装和破解
https://blog.csdn.net/qq1031893936/article/details/90264688 提示信息 - 吾爱破解 - LCG - LSG |安卓破解|病毒分析|www.52pojie.cn...
OSI七层模型
OSI(Open System Interconnect),即开放式系统互连。 该体系结构标准定义了网络互连的七层框架(物理层、数据链路层、网络层、传输层、会话层、表示层和应用层 ),即OSI开放系统互连参考模型。 应用层 为用…...
Qt自定义MessageToast
效果: 文字长度自适应,自动居中到parent,会透明渐变消失。 CustomToast::MessageToast(QS("最多添加50张图片"),this);1. CustomToast.h #pragma once#include <QFrame>class CustomToast : public QFrame {Q_OBJECT pub…...
自动化测试 pytest 中 scope 限制 fixture使用范围!
导读 fixture 是 pytest 中一个非常重要的模块,可以让代码更加简洁。 fixture 的 autouse 为 True 可以自动化加载 fixture。 如果不想每条用例执行前都运行初始化方法(可能多个fixture)怎么办?可不可以只运行一次初始化方法? 答…...
软件-vscode-plantUML-drawio
文章目录 vscode基础命令 实操1. vscode实现springboot项目搭建 (包括spring data jpa和sqlLite连接) PlantUMLDrawio基础实操 vscode 基础 命令 启动mysql命令 docker run --name mysql-container -e MYSQL_ROOT_PASSWORD123456 -p 3306:3306 -d my…...
Python爬虫实战案例(爬取图片)
爬取图片的信息 爬取图片与爬取文本内容相似,只是需要加上图片的url,并且在查找图片位置的时候需要带上图片的属性。 这里选取了一个4K高清的壁纸网站(彼岸壁纸https://pic.netbian.com)进行爬取。 具体步骤如下: …...
智慧工地视频汇聚管理平台:打造现代化工程管理的全新视界
一、方案背景 科技高速发展的今天,工地施工已发生翻天覆地的变化,传统工地管理模式很容易造成工地管理混乱、安全事故、数据延迟等问题,人力资源的不足也进一步加剧了监管不到位的局面,严重影响了施工进度质量和安全。 视频监控…...
ASP.NET中的六大对象有哪些?以及各自的功能以及使用方式
在ASP.NET Web Forms中,并没有严格意义上的“六大对象”,但通常我们指的是与HTTP请求和响应处理紧密相关的几个内置对象。以下是这些对象及其功能、使用方式以及简单的实现源码示例: Response对象 功能:用于向客户端发送HTTP响应…...
Admin.Net中的消息通信SignalR解释
定义集线器接口 IOnlineUserHub public interface IOnlineUserHub {/// 在线用户列表Task OnlineUserList(OnlineUserList context);/// 强制下线Task ForceOffline(object context);/// 发布站内消息Task PublicNotice(SysNotice context);/// 接收消息Task ReceiveMessage(…...
【HarmonyOS 5.0】DevEco Testing:鸿蒙应用质量保障的终极武器
——全方位测试解决方案与代码实战 一、工具定位与核心能力 DevEco Testing是HarmonyOS官方推出的一体化测试平台,覆盖应用全生命周期测试需求,主要提供五大核心能力: 测试类型检测目标关键指标功能体验基…...
(二)TensorRT-LLM | 模型导出(v0.20.0rc3)
0. 概述 上一节 对安装和使用有个基本介绍。根据这个 issue 的描述,后续 TensorRT-LLM 团队可能更专注于更新和维护 pytorch backend。但 tensorrt backend 作为先前一直开发的工作,其中包含了大量可以学习的地方。本文主要看看它导出模型的部分&#x…...
FastAPI 教程:从入门到实践
FastAPI 是一个现代、快速(高性能)的 Web 框架,用于构建 API,支持 Python 3.6。它基于标准 Python 类型提示,易于学习且功能强大。以下是一个完整的 FastAPI 入门教程,涵盖从环境搭建到创建并运行一个简单的…...
Leetcode 3577. Count the Number of Computer Unlocking Permutations
Leetcode 3577. Count the Number of Computer Unlocking Permutations 1. 解题思路2. 代码实现 题目链接:3577. Count the Number of Computer Unlocking Permutations 1. 解题思路 这一题其实就是一个脑筋急转弯,要想要能够将所有的电脑解锁&#x…...
大语言模型如何处理长文本?常用文本分割技术详解
为什么需要文本分割? 引言:为什么需要文本分割?一、基础文本分割方法1. 按段落分割(Paragraph Splitting)2. 按句子分割(Sentence Splitting)二、高级文本分割策略3. 重叠分割(Sliding Window)4. 递归分割(Recursive Splitting)三、生产级工具推荐5. 使用LangChain的…...
【2025年】解决Burpsuite抓不到https包的问题
环境:windows11 burpsuite:2025.5 在抓取https网站时,burpsuite抓取不到https数据包,只显示: 解决该问题只需如下三个步骤: 1、浏览器中访问 http://burp 2、下载 CA certificate 证书 3、在设置--隐私与安全--…...
MySQL用户和授权
开放MySQL白名单 可以通过iptables-save命令确认对应客户端ip是否可以访问MySQL服务: test: # iptables-save | grep 3306 -A mp_srv_whitelist -s 172.16.14.102/32 -p tcp -m tcp --dport 3306 -j ACCEPT -A mp_srv_whitelist -s 172.16.4.16/32 -p tcp -m tcp -…...
大数据学习(132)-HIve数据分析
🍋🍋大数据学习🍋🍋 🔥系列专栏: 👑哲学语录: 用力所能及,改变世界。 💖如果觉得博主的文章还不错的话,请点赞👍收藏⭐️留言Ǵ…...
Git 3天2K星标:Datawhale 的 Happy-LLM 项目介绍(附教程)
引言 在人工智能飞速发展的今天,大语言模型(Large Language Models, LLMs)已成为技术领域的焦点。从智能写作到代码生成,LLM 的应用场景不断扩展,深刻改变了我们的工作和生活方式。然而,理解这些模型的内部…...
