php data image保存图片,php 接收上传的data:image/png;base64图片数据,并存储

前端上传图片发送过来的图片数

7d7cf0110566786b90d14054d76daee4.png

后台接收处理方法/*

* base64 图片上传

* $base64_image_content string 图片base64数据

* $path 图处存储地址,从网站根路径开如

* return string  图片地址

*/

private function base64Img($base64_image_content,$path){

//匹配出图片的格式

if (preg_match('/^(data:\s*image\/(\w+);base64,)/', $base64_image_content, $result)){

$type = $result[2];

$new_file = $path;

if(!file_exists($new_file)){

//检查是否有该文件夹,如果没有就创建,并给予最高权限

mkdir($new_file, 0700);

}

$new_file = $new_file.uniqid().".{$type}";

if (file_put_contents($new_file, base64_decode(str_replace($result[1], '', $base64_image_content)))){

return '/'.$new_file;

}else{

return false;

}

}else{

return false;

}

}

如果需要判断上传的数据类型,可以根据以下类型判断

目前,Data URI scheme支持的类型有:

data:,文本数据

data:text/plain,文本数据

data:text/html,HTML代码

data:text/html;base64,base64编码的HTML代码

data:text/css,CSS代码

data:text/css;base64,base64编码的CSS代码

data:text/javascript,Javascript代码

data:text/javascript;base64,base64编码的Javascript代码

编码的gif图片数据

编码的png图片数据

编码的jpeg图片数据

编码的icon图片数据

首先,我们需要用Python进行网页爬取,找到包含data:image/png;base64格式图片的标签。可以使用BeautifulSoup库来解析网页,并使用find方法找到img标签中class为comicimg的元素,然后获取其src属性,即为图片数据base64编码字符串。 接下来,我们需要将base64编码的字符串解码,并保存为图片文件。可以使用base64库的b64decode方法将字符串解码为二进制数据。然后,我们可以将解码后的数据写入文件中。 请注意,有时候导出来的图片可能是空白的,这可能是因为解码后的数据不正确,或者图片本身就是空白的。在存储图片之前,可以尝试将解码后的数据进行保存并查看,以确保数据正确。 下面是一个示例代码,可以实现爬取data:image/png;base64格式图片并保存的功能: ```python import requests import base64 # 发送请求获取网页内容 url = 'http://example.com' # 替换为目标网页的URL response = requests.get(url) html = response.text # 解析网页内容 from bs4 import BeautifulSoup bs = BeautifulSoup(html, 'html.parser') # 获取图片数据base64编码字符串 strings = str(bs.find(name="img", attrs={"class": "comicimg"}).get('src')) # 解码base64编码的字符串 head, encode = strings.split(',', 1) image_data = base64.b64decode(encode) # 将解码后的数据保存为图片文件 with open('image.png', 'wb') as f: f.write(image_data) ``` 以上代码可以爬取指定URL的网页内容,并查找class为comicimg的img标签,获取其中的图片数据。然后将图片数据解码并保存为image.png文件。请注意,需要将代码中的url替换为你要爬取的网页的URL,以及根据需要修改保存的文件名。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [python爬取图片遇见src乱码: data:image/png;base64](https://blog.csdn.net/weixin_39834780/article/details/114445179)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值