diff --git a/examples/simple_example/api_v1_ApiTest.cc b/examples/simple_example/api_v1_ApiTest.cc index 0f2cc349..8ae2d15a 100755 --- a/examples/simple_example/api_v1_ApiTest.cc +++ b/examples/simple_example/api_v1_ApiTest.cc @@ -34,6 +34,7 @@ void ApiTest::your_method_name(const HttpRequestPtr &req, const std::function para; para["p1"] = std::to_string(p1); para["p2"] = std::to_string(p2); + para["p3"] = HttpViewData::htmlTranslate(""); data.insert("parameters", para); auto res = HttpResponse::newHttpViewResponse("ListParaView", data); callback(res); diff --git a/lib/inc/drogon/HttpViewData.h b/lib/inc/drogon/HttpViewData.h index 626e1b67..9467d642 100755 --- a/lib/inc/drogon/HttpViewData.h +++ b/lib/inc/drogon/HttpViewData.h @@ -119,6 +119,15 @@ class HttpViewData return _viewData[key]; } + /// Translate some special characters to HTML format, such as: + /** + * " --> " + * & --> & + * < --> < + * > --> > + */ + static std::string htmlTranslate(const std::string &str); + protected: typedef std::unordered_map ViewDataMap; mutable ViewDataMap _viewData; diff --git a/lib/src/HttpViewData.cc b/lib/src/HttpViewData.cc new file mode 100644 index 00000000..1778e2c5 --- /dev/null +++ b/lib/src/HttpViewData.cc @@ -0,0 +1,45 @@ +/** + * + * HttpViewData.cc + * An Tao + * + * Copyright 2018, An Tao. All rights reserved. + * https://github.com/an-tao/drogon + * Use of this source code is governed by a MIT license + * that can be found in the License file. + * + * Drogon + * + */ + +#include + +using namespace drogon; + +std::string HttpViewData::htmlTranslate(const std::string &str) +{ + std::string ret; + ret.reserve(str.length()); + for (auto &ch : str) + { + switch (ch) + { + case '"': + ret.append("""); + break; + case '<': + ret.append("<"); + break; + case '>': + ret.append(">"); + break; + case '&': + ret.append("&"); + break; + default: + ret.push_back(ch); + break; + } + } + return ret; +} \ No newline at end of file