我正在尝试使用drakma将一些JSON数据发布到web服务。
(ql:quickload :st-json)
(ql:quickload :cl-json)
(ql:quickload :drakma)
(defvar *rc* (merge-pathnames (user-homedir-pathname) ".apirc"))
(defvar *user*
(with-open-file (s *rc*)
(st-json:read-json s)))
(defvar api-url (st-json:getjso "url" *user*))
(defvar api-key (st-json:getjso "key" *user*))
(defvar api-email (st-json:getjso "email" *user*))
(setf drakma:*header-stream* *standard-output*)
(defvar *req* '(("date" . "20071001") ("time" . "00") ("origin" . "all")))
(format t "json:~S~%" (json:encode-json-to-string *req*))
(defun retrieve (api request)
(let* ((cookie-jar (make-instance 'drakma:cookie-jar))
(extra-headers (list (cons "From" api-email)
(cons "X-API-KEY" api-key)))
(url (concatenate 'string api-url api "/requests"))
(stream (drakma:http-request url
:additional-headers extra-headers
:accept "application/json"
:method :post
:content-type "application/json"
:external-format-out :utf-8
:external-format-in :utf-8
:redirect 100
:cookie-jar cookie-jar
:content (json:encode-json-to-string request)
:want-stream t)))
(st-json:read-json stream)))
(retrieve "/datasets/tigge" *req*)不幸的是,我得到了一个错误,尽管我认为JSON和drakma生成的头似乎编码正确。显然,:content出了问题(错误消息中的整数列表就是JSON编码数据的ASCII码列表)。
json:"{\"date\":\"20071001\",\"time\":\"00\",\"origin\":\"all\",\"type\":\"pf\",\"param\":\"tp\",\"area\":\"70\\/-130\\/30\\/-60\",\"grid\":\"2\\/2\",\"target\":\"data.grib\"}"
POST /v1/datasets/tigge/requests HTTP/1.1
Host: api.service.int
User-Agent: Drakma/1.3.0 (SBCL 1.1.5; Darwin; 12.2.0; http://weitz.de/drakma/)
Accept: application/json
Connection: close
From: me@gmail.com
X-API-KEY: 19a0edb6d8d8dda1e6a3b21223e4f86a
Content-Type: application/json
Content-Length: 193
debugger invoked on a SIMPLE-TYPE-ERROR:
The value of CL+SSL::THING is #(123 34 100 97 116 97 115 101 116 34 58 34
...), which is not of type (SIMPLE-ARRAY
(UNSIGNED-BYTE 8)
(*)).你知道这段代码出了什么问题吗?在此之前,非常感谢您。
发布于 2013-03-22 17:58:03
感谢戏剧和Chunga drakma-devel的一般兴趣列表中的凯文和汉斯帮助我解决了这个问题-事实证明,这个问题是由最近版本的cl+ssl中的一个bug引起的,这个bug已经在一个开发分支中得到了修复。我使用quicklisp,以下是Hans Hübner建议我更新我的cl+ssl安装的方法,它起作用了:
您可以查看最新的cl+ssl -其中包含对该问题的修复:
cd ~/quicklisp/本地项目/ git克隆git://gitorious.org/cl-plus-ssl/cl-plus-ssl.git
Quicklisp将自动从该位置查找cl+ssl。记得在升级到更新的quicklisp发行版后删除该签出,该发行版将来会有修复。
https://stackoverflow.com/questions/15557383
复制相似问题