php上传图片并存入数据库


PHP上传图片

1 链接数据库

<?php 
	$server = "localhost";
	$user = "root";
	$password = "root";
	$db = "shoping";
	function connect($servername,$username,$password,$dbname){
	    // 创建连接
	    $conn = mysqli_connect($servername, $username, $password, $dbname);
	    // $this->conn = $conn;
	    // 检测连接
	    if ($conn->connect_error) {
	        die("连接失败: " . $conn->connect_error);
	    }else{
	        // echo 'cg';
			return $conn;
	    }
	};
	
?>

2 编写上传方法

<?php
function moveimg($file,$path,$name){
    if(move_uploaded_file($file,$path.'/'.$name)){
        //  echo json_encode($_POST);
        echo 'yes';
    }else{
        echo 'no';
    }
}
?>

3 上传并存入数据库

<?php
    header('Content-Type: text/html;charset=utf-8');
    header('Access-Control-Allow-Origin:*'); // *代表允许任何网址请求
    include('../flieControl/moveimg.php');
    include('../mysql/linksql.php');
    $conn =  connect($server,$user,$password,$db );
    // 要移动到的文件夹
    $filepath = '/Applications/phpstudy/WWW/shopingdb/img/';
    // 要移动的文件临时位子
    $file = $_FILES['file']['tmp_name'];
    // 要移动的文件名
    $filename = $_FILES['file']['name'];
    // 文件的分类
    $PATH = $filepath.$_POST['class'];
    // 判断目录存不存在
    $path = file_exists($PATH);
    if($path){
        // 文件移动方法
       moveimg($file,$PATH,$filename);
    }else{
        mkdir($PATH,0777,true);
        moveimg($file,$PATH,$filename);
    }
 
?>
要将文件上传到MySQL数据库,需要先将文件转换成二进制数据,然后将其插入到数据库中的BLOB类型字段中。以下是使用Layui上传图片并将其存入MySQL数据库的示例: 1. 在HTML中添加文件上传表单: ```html <form class="layui-form" action="" enctype="multipart/form-data"> <div class="layui-form-item"> <div class="layui-upload"> <button type="button" class="layui-btn" id="uploadBtn">上传图片</button> <div class="layui-upload-list"> <img class="layui-upload-img" id="previewImg"> <p id="previewText"></p> </div> </div> </div> </form> ``` 2. 引入Layui和jQuery库: ```html <link rel="stylesheet" href="https://cdn.staticfile.org/layui/2.5.6/css/layui.min.css"> <script src="https://cdn.staticfile.org/jquery/3.5.1/jquery.min.js"></script> <script src="https://cdn.staticfile.org/layui/2.5.6/layui.min.js"></script> ``` 3. 初始化Layui上传组件: ```javascript layui.use('upload', function(){ var upload = layui.upload; //执行上传 var uploadInst = upload.render({ elem: '#uploadBtn', //绑定元素 url: '/upload/', //上传接口 accept: 'images', //允许上传的文件类型 size: 1024, //限制文件大小,单位KB done: function(res){ //上传成功回调 $('#previewImg').attr('src', res.data.src); //显示预览图 $('#previewText').html(res.data.title); //显示文件名 //将文件二进制数据存入数据库 $.ajax({ type: 'POST', url: '/saveToDB/', data: { imageData: res.data.imageData //文件的二进制数据 }, success: function(data){ console.log(data); }, error: function(){ console.log('上传失败'); } }); }, error: function(){ //上传失败回调 console.log('上传失败'); } }); }); ``` 4. 在服务器端处理上传的文件,并将其存入MySQL数据库: ```php <?php //获取上传的文件二进制数据 $imageData = file_get_contents($_FILES['file']['tmp_name']); //连接MySQL数据库 $servername = "localhost"; $username = "username"; $password = "password"; $dbname = "dbname"; $conn = new mysqli($servername, $username, $password, $dbname); //将文件二进制数据插入到数据库中 $stmt = $conn->prepare("INSERT INTO images (image_data) VALUES (?)"); $stmt->bind_param("b", $imageData); $stmt->execute(); $stmt->close(); $conn->close(); ?> ``` 注意:以上代码仅供参考,具体实现需要根据自己的实际情况进行调整。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值