8

Happstack を使用して JSON REST API を作成しようとしています。JSON 本文を含む POSTS を許可する必要があります。これどうやってするの?happstack の API のすべての関数は、パラメーター名に基づいて検索しているようです。本文は常に URL エンコードされていると見なされます。

Happstack でそれができない場合、どのフレームワークを使用すればよいですか?

4

1 に答える 1

11

さて、これが私が理解したものです。

{-# LANGUAGE OverloadedStrings, DeriveDataTypeable #-}
import qualified Data.ByteString.Lazy.Char8 as L
import Happstack.Server
import Happstack.Server.Types
import Control.Monad.IO.Class (liftIO)

import Data.Data (Data, Typeable)

-- easiest to serialize/deserialize objects
data Unit = Unit { x :: Int, y :: Int } deriving (Show, Eq, Data, Typeable)

-- put this function in a library somewhere
getBody :: ServerPart L.ByteString
getBody = do
    req  <- askRq 
    body <- liftIO $ takeRequestBody req 
    case body of 
        Just rqbody -> return . unBody $ rqbody 
        Nothing     -> return "" 

myRoute :: ServerPart Response
myRoute = do
    body <- getBody -- it's a ByteString
    let unit = fromJust $ A.decode body :: Unit -- how to parse json
    ok $ toResponse $ A.encode unit -- how to send json back. 
于 2012-01-14T22:42:09.177 に答える