php - 如何通过 PHP 从 Swift 将 UIImage 上传到 MySQL?

标签 php ios mysql image swift

我有一个应用程序,可以通过我编写的一些 PHP Web 服务将一些数据上传到 MySQL 数据库。我已经成功上传了文本数据,但我正在努力尝试上传图像。基本上,用户使用 iPhone 相机拍摄照片,我将其转换为 UIImage,现在想要上传它。

我已查看以下来源寻求帮助,但它们似乎对我不起作用: How to Upload text, pdf, doc, zip file via PHP file upload to MySQL
https://www.youtube.com/watch?v=HqxeyS961Uk (这里的代码无法为我编译,我逐字复制)
How to post a picture from iPhone app (in Swift) to MySQL database?
Saving image on db mysql through swift
Swift - uploading base64 encoded image to php and displaying the image
Getting a UIImage from MySQL using PHP and jSON

如果可能的话,我想在同一个查询中一起上​​传图像和文本,因为它们彼此相关,并且我的 MySQL 表为新行分配一个自动编号。

编辑 感谢下面的回答。我有点不确定如何实现你们建议的改变。我目前上传文本数据的 Swift 代码是:

let url:NSURL = NSURL(string: "http://www.website.com.au/savenewexpense.php")!
        let request:NSMutableURLRequest = NSMutableURLRequest(URL: url)
        request.HTTPMethod = "POST"
        var dataDictionary:[String:AnyObject] = ["Date" : strDate, "Staff" : strStaff, "Amount" : dblAmount, "Category" : strCategory]
        var data:NSData = NSJSONSerialization.dataWithJSONObject(dataDictionary, options: nil, error: nil)!
        request.HTTPBody = data

        request.addValue("application/json", forHTTPHeaderField: "Content-Type")

        let task:NSURLSessionDataTask = NSURLSession.sharedSession().dataTaskWithRequest(request, completionHandler: { (data:NSData!, response:NSURLResponse!, error:NSError!) -> Void in

            let response:[String:String] = NSJSONSerialization.JSONObjectWithData(data, options: NSJSONReadingOptions.MutableContainers, error: nil) as! [String:String]
            if let result = response["result"] {
                if result == "success" {
                    NSLog("Text Data saved successfully")
                    if self.SendImageToServer() == true {
                        NSLog("Image Data saved successfully")
                        self.SaveSuccessful()
                    } else {
                        NSLog("Image Data failed to save")
                        self.DataFail()
                    }
                } else {
                    NSLog("Error saving data")
                    self.DataFail()
                }
            } else {
                NSLog("No response")
                self.NoResponse()
            }

        })

        task.resume()
    }

我的 PHP 代码是:

    // Create connection
$conn = new mysqli($servername, $username, $password, $dbname);

// Check connection
if ($conn->connect_error) {
    die("Connection failed: " . $conn->connect_error);
}

$json = file_get_contents('php://input');
$data = json_decode($json, true);

$stmt = $conn->prepare("INSERT INTO tblExpenses (Date, Staff, Amount, Category) VALUES (?, ?, ?, ?)");
$txtDate = $data['Date'];
$txtStaff = $data['Staff'];
$txtAmount = $data['Amount'];
$txtCategory = $data['Category'];
$stmt->bind_param("ssds", $txtDate, $txtStaff, $txtAmount, $txtCategory);
$stmt->execute();
echo '{"result" : "success"}';


$stmt->close();
$conn->close();

我应该如何将图像实现到其中?

谢谢

最佳答案

您要做的就是设置图像的边界,例如使用代码将图像的 NSDATA 转换为边界值

if let dta = data as? NSData {
                bodyData.appendData(String(format:"\r\n--\(boundary)\r\n").dataUsingEncoding(NSUTF8StringEncoding, allowLossyConversion: false)!);
                bodyData.appendData(String(format:"Content-Disposition: form-data; name=\"photo\(i)\"; filename=\"image.png\"\r\n").dataUsingEncoding(NSUTF8StringEncoding, allowLossyConversion: false)!);
                bodyData.appendData(String(format:"Content-Type: image/png\r\n\r\n").dataUsingEncoding(NSUTF8StringEncoding, allowLossyConversion: false)!);

                bodyData.appendData(dta);
            }

在这里,您要做的是设置图像名称,然后设置图像数据,首先使用 allowLossyConversion 转换数据,然后将 POST 数据与其他数据一起发送到服务

request.HTTPBody = bodyData

只需使用它来发送图像

关于php - 如何通过 PHP 从 Swift 将 UIImage 上传到 MySQL?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30158868/

相关文章:

php - 获取 <select> 中 <option> 的内容而不是值

php - CentOS 7 上带有 Apache 的多个 PHP 版本

c++ - Xcode 初学者。新文件问题和错误

php - 将嵌套 sql SELECT 语句中的 SELECT 结果分配给变量 - PHP

mysql - 根据可变时期对日期进行分组

php - 使用 LinkedIn V2 API 上传视频

php - 如何使用 perl/php/grep/etc 从 csv 中提取日期范围?

javascript - IOS 在输入焦点上显示键盘

ios - AFNetworking 全局提示用户登录 401 错误代码?

mysql - RewriteMap MapType dbd 的问题