API: return response as HTML table

想要把response table变成HTML的table,即想达到下面这种的话

<table boarder="1" style="width:100%; boarder-collapse: collapse; text-align:left">

<tr>

<th>Customer</th>

<th>Date</th>

<th>Debit Amount</th>

<th>Payment Amount</th>

<th>Remain Balance</th>

</tr>

<tr>

<td>40000446</td>

<td>20250501</td>

<td>17227.80</td>

<td>0.00</td>

<td>17227.80</td>

</tr>

<tr>

<td>40000446</td>

<td>20250515</td>

<td>54.52</td>

<td>0.00</td>

<td>54.52</td>

</tr>

</table>

可以这样子开发:

METHOD if_http_extension~handle_request.

DATA: lv_jsonbody TYPE string,

lv_xstring TYPE xstring,

lv_html_string TYPE string.

"get Request Body: JSON->ABAP

lv_jsonbody = server->request->get_cdata( ).

CALL METHOD /ui2/cl_json=>deserialize

EXPORTING

json = lv_jsonbody

pretty_name = /ui2/cl_json=>pretty_mode-none

assoc_arrays = abap_true

CHANGING

data = ms_req.

**********************************************************************

CALL METHOD me->pre_requisition.

CALL METHOD me->business_logic.

**********************************************************************

lv_html_string = '<table boarder = "1" style = "width:100%; boarder-collapse: collapse; text-align:left">'.

lv_html_string = lv_html_string && '<tr><th>Customer</th><th>Date</th><th>Debit Amount</th><th>Payment Amount</th><th>Remain Balance</th></tr>'.

LOOP AT mt_resp ASSIGNING FIELD-SYMBOL(<resp>).

lv_html_string = lv_html_string && '<tr>'.

lv_html_string = lv_html_string && '<td>' && <resp>-customer && '</td>'.

lv_html_string = lv_html_string && '<td>' && <resp>-date && '</td>'.

lv_html_string = lv_html_string && '<td>' && <resp>-debit_amount && '</td>'.

lv_html_string = lv_html_string && '<td>' && <resp>-payment_amount && '</td>'.

lv_html_string = lv_html_string && '<td>' && <resp>-remain_balance && '</td>'.

lv_html_string = lv_html_string && '</tr>'.

ENDLOOP.

lv_html_string = lv_html_string && '</table>'.

**********************************************************************

CALL METHOD server->response->set_content_type( if_rest_media_type=>gc_text_html ).

CALL METHOD server->response->set_cdata(

EXPORTING

data = lv_html_string ).

CALL METHOD server->response->set_status(

EXPORTING

code = 201

reason = 'Executed' ).

ENDMETHOD.

相关推荐
沉默璇年1 天前
如何通过python脚本下载高德离线底图瓦片并使用?
javascript·python·html
BianHuanShiZhe1 天前
swift计算文本高度
前端·javascript·html
23级二本计科1 天前
前端 HTML + CSS + JavaScript
前端·css·html
VekiSon1 天前
综合项目实战——电子商城信息查询系统
linux·c语言·网络·http·html·tcp·sqlite3
用户51414448098241 天前
section与article的区别与使用场景
html
程序员小李白1 天前
定位.轮播图详细解析
前端·css·html
2301_773730311 天前
系统编程—在线商城信息查询系统
c++·html
软件开发技术深度爱好者2 天前
JavaScript的p5.js库使用介绍
javascript·html
lgliuying2 天前
wangEditor5 富文本编辑器中使用 kityformula 公式编辑器的具体实践
前端·javascript·html
亚历山大海2 天前
PHP HTML 实体(HTML Entities)没有被正确解码导致< 和 δ 等字符被转换
开发语言·html·php