8

我正在尝试编写一个允许用户将文件上传到我的服务器的表单。我看到 Yesod 使用 fileAFormReq 来实现这样的功能,但无法让它工作,遇到编译错误,最新的是:“No instance for (RenderMessage MySite t)”任何关于如何使用它的精简示例都是高度赞赏。谢谢,乌里

4

1 回答 1

13

2012 年 9 月 13 日更新:

这里有一个官方维护的文件上传帮助页面


谷歌搜索功能fileAFormReq给了我这个例子

我只用相关部分制作了它的最小版本。

{-# LANGUAGE OverloadedStrings #-}
{-# LANGUAGE QuasiQuotes, TypeFamilies, TemplateHaskell, MultiParamTypeClasses #-}
import Yesod.Core
import Yesod.Form
import Yesod.Form.MassInput
import Control.Applicative
import Data.Text (Text, pack)
import Network.Wai.Handler.Warp (run)
import Data.Time (utctDay, getCurrentTime)
import qualified Data.Text as T
import Control.Monad.IO.Class (liftIO)

mkYesod "HelloForms" [parseRoutes|
/file FileR GET POST
|]

data HelloForms = HelloForms

instance RenderMessage HelloForms FormMessage where
    renderMessage _ _ = defaultFormMessage

instance Yesod HelloForms where
    approot _ = ""


main = toWaiApp HelloForms >>= run 3000

fileForm = renderTable $ pure (,)
    <*> fileAFormReq "Required file"
    <*> fileAFormOpt "Optional file"

getFileR = do
    ((res, form), enctype) <- runFormPost fileForm
    defaultLayout [whamlet|
<p>Result: #{show res}
<form method=post enctype=#{enctype}>
    <table>
        ^{form}
    <tr>
        <td>
            <input type=submit>
|]

postFileR = getFileR

runhaskell然后http://localhost:3000/file在浏览器中访问。

希望这可以帮助。:)


编辑:

哦等等,很明显你错过了什么。正如刚才所说的编译错误,你RenderMessage的 Foundation 缺少一个实例。

我知道最近为 i18n 所做的努力稍微改变了 forms-package。如果您使用的是最新版本的 yesod,请查看内容。

我粘贴的代码使用旧的非 i18n(默认为英文)版本的yesod-forms包。

于 2011-09-18T09:50:42.227 回答