到底怎样才能把文件保存到SQLSERVER数据库呢?
目前我表中存放文件的字段类型为BINARY。源程序为:
if($upfile!='')
{
$PSize = filesize($upfile);
$mssqldoc = addslashes(fread(fopen($upfile, "r"), $PSize));
$upfiletype = strtolower(substr( strrchr( $upfile_name, "." ), 1 ) );
mssql_connect("$server", "$user", "$pass") or die("Unable to connect to SQL server");
@mssql_select_db("$database") or die("Unable to select database");
$sql="insert into document (do_file,do_timeadded,do_type) values (";
$sql.="$mssqldoc,getdate(),'$upfiletype')";
$db->query($sql);
出错提示:
Warning: MS SQL message: Line 185: Incorrect syntax near '迟0'. (severity 15) in e:\program\program_php\project\include\mssql.php on line 89
Warning: MS SQL message: Unclosed quotation mark before the character string ')'. (severity 15) in e:\program\program_php\project\include\mssql.php on line 89
Warning: MS SQL: Query failed in e:\program\program_php\project\include\mssql.php on line 89
拜托都来看看,我急着用。谢谢了!
---------------------------------------------------------------
try these code:
if($upfile!='')
{
$PSize = filesize($upfile);
$mssqldoc = addslashes(fread(fopen($upfile, "rb"), $PSize));
$upfiletype = strtolower(substr( strrchr( $upfile_name, "." ), 1 ) );
mssql_connect($server, $user, $pass) or die("Unable to connect to SQL server");
@mssql_select_db($database) or die("Unable to select database");
$sql="insert into document (do_file,do_timeadded,do_type) values (";
$sql.="'$mssqldoc',getdate(),'$upfiletype')";
$db->query($sql);
---------------------------------------------------------------
用PHP实现文件上传二法
(作者:王锋 2001年04月26日 10:58)
PHP(Hypertext Preprocessor)是一种 HTML 内嵌式的语言 (类似 IIS 上的ASP)。而 PHP 独特的语法混合了 C、Java、Perl 以及 PHP 式的新语法。它可以比 CGI 或者 Perl 更快速的执行动态网页。除此之外,用 PHP 写出来的 Web 后端CGI 程序,可以很轻易的移植到不同的系统平台上。
我们在做网站时,需要访问者的参于才能将网站建设得更加引人注目,这就要求我们从访问者那里得到文章、图片等。因此,文件上传成为网页中必不可少的功能。现在我就利用现在流行的编程语言PHP,用两种方法来说明其功能的实现。
一、利用php的文件函数来实现上传
这段代码分为两个文件,一个为upload.html,一个是upload.php。
上传文件选择:upload.html 代码如下:
--------------------------------------------------------------------------------
1<html><head><title>上载文件表单</title></head>
2<body>
3<form action="upload.php" enctype="multipart/form-data" method="post">
4<input name="max_file_size" type="hidden" value="100000"/>
5<center>请选择文件:
6
7<input name="userfile" type="file"/>
8<input type="submit" value="上传文件"/>
9</center>
10</form>
11</body>
12</html>
--------------------------------------------------------------------------------
*** 说明 ***
1、请注意
1<form ......="" enctype="multipart/form-data">这是一个标签,我们要实现文件的上传,必须指定为 multipart/form-data ,否则服务器将不知道你在干什么!
2
32、值得注意的是文件upload.html中表单选项 MAX_FILE_SIZE 的隐藏值域,通过设置
4
5其Value(值)可以限制上载文件的大小。
6
7
8处理刚刚上传的文件:upload.php 代码如下:
9
10
11\--------------------------------------------------------------------------------
12
13<html>
14<head>
15<title>处理上载文件</title>
16</head>
17<body>
18<?
19
20copy($userfile,"newfile");
21
22echo $userfile."-用户上传到服务器上的文件临时存放的名称<br>";
23
24echo $userfile_name."-在用户机器上该文件的原始名称<br/>";
25
26echo $userfile_size."-上传文件的实际字节数<br/>";
27
28echo $userfile_type."-如果用户的浏览器提供了这个信息的话,它表示mime的类型。例如image/gif<br/>";
29
30?>
31
32</body>
33</html>
34
35
36\--------------------------------------------------------------------------------
37
38*** 说明 ***
39
401、使用了PHP文件函数copy()将上载到临时目录下的文件拷贝到一个特定的目录下,并重新命名为"newfile"。
41
422、在upload.html中定义了一个变量 userfile,在upload.php中,我们就可以使用这个变量,直接通过$userfile访问上载的文件,但由于这是一个保存文件的变量,因此文件名字必须通过另外一个$userfile_name变量取得。
43
44下面是这个变量的具体用法:
45
46$userfile:在将要存放上载文件的服务器上的临时文件名字。
47
48$userfile_name:在发送者系统中的初始文件名。
49
50$userfile_size:按字节计算的上载文件的大小。
51
52$userfile_type:多用途网际邮件扩充协议类型的文件,前提是浏览器提供这种信息,比如说“image/gif"。
53
54
55
56二、利用FTP功能进行文件上传
57这段代码同样分为两个文件,一个为upload.php,一个是ftp.php。
58
59
60设置ftp的相关选项及选择上传文件名:upload.php 代码如下:
61
62
63\--------------------------------------------------------------------------------
64
$username="用户名";
$password="用户密码";
$server="主机名";
$cdir="上传目录名" ;
//以上设置你的FTP主机名、用户名和用户密码
1
2<!-- 文件上传设置标签 -->
3<form action="ftp.php" enctype="multipart/form-data" method="post">
4<!-- 传递变量 -->
5<input $username;="" ?="" echo="" name="username" type="hidden" value="<?"/>>
6
7<input $password;="" ?="" echo="" name="password" type="hidden" value="<?"/>>
8
9<input $server;="" ?="" echo="" name="server" type="hidden" value="<?"/>>
10
11<input $cdir;="" ?="" echo="" name="cdir" type="hidden" value="<?"/>>
12
13<table>
14<tr>
15<td>上传文件选择
16
17<input name="upfile" type="file"/>
18</td>
19</tr>
20<tr>
21<td>
22<!-- 提交表单 -->
23<input name="action" type="submit" value="上传"/>
24</td>
25</tr>
26</table>
27</form>
28
29
30\--------------------------------------------------------------------------------
31
32
33处理上传文件:ftp.php 代码如下:
34
35
36\--------------------------------------------------------------------------------
37
//ftp联接主机函数
function connect()
{
global $server, $username, $password;
$conn = ftp_connect($server);
ftp_login($conn, $username, $password);
return $conn;
}
//建立ftp联接
$result = connect();
if ($action == "上传")
{
//用来改变ftp路径
ftp_chdir($result, $cdir);
//用来上传指定的文件,同名并以二进制位传递
$res_code = ftp_put($result, $upfile_name, $upfile, FTP_BINARY);
// 判断是否正确上传
if ($res_code == 1)
echo "上传成功!";
else
echo "上传错误!";
}
// 关闭联接
ftp_quit($result);
1
2
3\--------------------------------------------------------------------------------
4
5*** 说明 ***
6
7函数ftp_put(int ftp_stream, string remote_file, string local_file, int mode)用法
8
9返回值: 布尔值
10
11本函数用来上传指定的文件。参数 ftp_stream 为 FTP 的连接代码。参数 remote_file 为欲存在远端的文件名。参数 local_file 为欲上传文件的文件名。参数 mode 的值有 FTP_ASCII 及 FTP_BINARY 二种,分别表示文档或者是二进位文件。成功则返回 true 值,失败则返回 false 值。</form>