1.减少了HTTP请求
2.某些文件可以避免跨域的问题
3.没有图片更新要重新上传,还要清理缓存的问题
不足在于:
1.浏览器支持使用base64编码图片作为背景图片的这种技术IE6/IE7浏览器是不支持的(IE9浏览器IE7模式下支持,这里被@前端的那点破事鄙视了 )。对于目前PC页面,兼容性问题使没有文件上传以及无需更新缓存的优点不存在了。
2.增加了CSS文件的尺寸base64编码图片本质上是将图片的二进制大小以一些字母的形式展示,例如一个1024字节的图片,base64编码后至少1024个字符,这个大小会被完全嵌入到CSS文件中(不过幸运的是也可以被gzip了,而图片文件被gzip效果不明显)。
3.编码成本图片完成后还需要base64编码,目前估计手工完成的多,因此,增加了一定的工作量,虽然不多
图像服务器(image server)是一种专门用于处理图像文件和存储的特殊计算机。图像服务器通常比一般的个人计算机拥有更大的存储容量,并具有一些其他的功能,如磁盘镜像、多个网络接口卡、热备援多电源供应器。图像服务器主要提供图像有关服务,加快图像数据处理过程。电脑和图像服务器传输慢通过网卡属性设置或者关闭Windows功能就可以解决。
方案一:网卡属性设置
1、按下Win+Pause/Break组合键,在出现的系统属性界面,点击左上角“设备管理器”;
2、在设备管理器窗口,找到并展开电脑网卡,对着它单击鼠标右键,菜单中选择“属性”;
3、在网卡属性对话框,点击切换到“高级”选项卡界面,在“属性”列表中,点击选中“Large Send Offload v2(IPv4)[大型传送分载 v2(IPv4)]”,在窗口右侧,将“值”设置为“Disabled(关闭)”,然后点击底部确定按钮。
亿万克作为中国战略性新兴产业领军品牌,拥有中国第一、世界前二的行业领先技术,致力于新型数据中心建设,构筑云端安全数字底座,为客户提供集产品研发、生产、部署、运维于一体的服务器及IT系统解决方案业务,所有产品和技术完全拥有自主知识产权,应用领域涵盖云计算、数据中心、边缘计算、人工智能、金融、电信、教育、能源等,为客户提供全方位安全自主可控技术服务保障。
【感兴趣请点击此处,了解一下。 】
第一步:通过$_FILES获取文件信息。
第二步:指定新文件名称以及路径,并赋值给一个变量。
第三步:通过move_uploaded_file上传文件。
第四步:上传成功后,将数值存入数据库服务器目录即可。
代码如下
1.conn.php
<?
$host="localhost" //数据库服务器名称
$user="root" //用户名
$pwd="1721" //密码
$conn=mysql_connect($host,$user,$pwd)
mysql_query("SET
character_set_connection=gb2312,
character_set_results=gb2312,
character_set_client=binary",$conn)
if ($conn==FALSE)
{
echo "<center>服务器连接失败!<br>请刷新后重试。</center>"
return true
}
$databasename="database"//数据库名称
do
{
$con=mysql_select_db($databasename,$conn)
}while(!$con)
if ($con==FALSE)
{
echo "<center>打开数据库失败!<br>请刷新后重试。</center>"
return true
}
?>
2.upload.php
<?php
if ($_GET['action'] == "save"){
include_once('conn.php')
include_once('uploadclass.php')
$title=$_POST['title']
$pic=$uploadfile
if($title == "")
echo"<Script>window.alert('对不起!你输入的信息不完整!')history.back()</Script>"
$sql="insert into upload(title,pic) values('$title','$pic')"
$result=mysql_query($sql,$conn)
//echo"<Script>window.alert('信息添加成功')location.href='upload.php'</Script>"
}
?>
<html>
<head>
<title>文件上传实例</title>
</head>
<body>
<form method="post" action="?action=save" enctype="multipart/form-data">
<table border=0 cellspacing=0 cellpadding=0 align=center width="100%">
<tr>
<td width=55 height=20 align="center"> </TD>
<td height="16">
<table width="48%" height="93" border="0" cellpadding="0" cellspacing="0">
<tr>
<td>标题:</td>
<td><input name="title" type="text" id="title"></td>
</tr>
<tr>
<td>文件: </td>
<td><label>
<input name="file" type="file" value="浏览" >
<input type="hidden" name="MAX_FILE_SIZE" value="2000000">
</label></td>
</tr>
<tr>
<td> </td>
<td><input type="submit" value="上 传" name="upload"></td>
</tr>
</table></td>
</tr>
</table>
</form>
</body>
</html>
3.uploadclass.php
<?php$uploaddir = "upfiles/"//设置文件保存目录 注意包含/
$type=array("jpg","gif","bmp","jpeg","png")//设置允许上传文件的类型
$patch="/upload/"//程序所在路径
//获取文件后缀名函数
function fileext($filename)
{
return substr(strrchr($filename, '.'), 1)
}
//生成随机文件名函数
function random($length)
{
$hash = 'CR-'
$chars = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789abcdefghijklmnopqrstuvwxyz'
$max = strlen($chars) - 1
mt_srand((double)microtime() * 1000000)
for($i = 0 $i < $length $i++)
{
$hash .= $chars[mt_rand(0, $max)]
}
return $hash
}
$a=strtolower(fileext($_FILES['file']['name']))
//判断文件类型
if(!in_array(strtolower(fileext($_FILES['file']['name'])),$type))
{
$text=implode(",",$type)
echo "您只能上传以下类型文件: ",$text,"<br>"
}
//生成目标文件的文件名
else{
$filename=explode(".",$_FILES['file']['name'])
do
{
$filename[0]=random(10) //设置随机数长度
$name=implode(".",$filename)
//$name1=$name.".Mcncc"
$uploadfile=$uploaddir.$name
}
while(file_exists($uploadfile))
if (move_uploaded_file($_FILES['file']['tmp_name'],$uploadfile))
{
if(is_uploaded_file($_FILES['file']['tmp_name']))
{
echo "上传失败!"
}
else
{//输出图片预览
echo "<center>您的文件已经上传完毕 上传图片预览: </center><br><center><img src='$uploadfile'></center>"
echo "<br><center><a href='upload.htm'>继续上传</a></center>"
}
}
}
?>
欢迎分享,转载请注明来源:夏雨云
评论列表(0条)