A ideia básica é o que o @Gates VP descreveu. Eu uso underscore.js para iterar pelos arrays/objetos.
function formatLog(obj){
var log = "";
_.each(obj, function(val, key){
if(typeof(val) === "object" || typeof(val) === "array"){
// if we have a new list
log += "<ul>";
log += formatLog(val);
log += "</ul>";
}
else{
// if we are at an endpoint
log += "<li>";
log += (key + ": " + val);
log += "</li>";
}
});
return log;
}
Se você chamar
formatLog()
nos dados de exemplo que você forneceu, ele retorna - ServerAlias:GBIZ-WEB
- urltoken:CFID=10989&CFTOKEN=f07fe950-53926E3B-F33A-093D-3FCEFB&jsessionid=84303d29a229d1
- ID da sessão:84197a667053f63433672873j377e7d379101
- UUID:53934LBB-DB8F-79T6-C03937JD84HB864A338
- Modelo:/home/vagrant/dev/websites/g-bis/code/webroot/page/home/home.cfm, linha 3
- Conteúdo gerado:
- Mailto:
- Mensagem:Tag desconhecida:cfincflude.
- tagName:cfincflude
- RAW_TRACE:em cfhome2ecfm1296628853.runPage(/home/vagrant/dev/websites/nig-bis/code/webroot/page/home/home.cfm:3)
- ID:CFINCLUDE
- MODELO:/home/vagrant/dev/websites/nig-bis/code/webroot/page/home/home.cfm
- LINHA:3
- TIPO:CFML
- COLUNA:0
- RAW_TRACE:em cfdisplay2ecfm1093821753.runPage(/home/vagrant/dev/websites/nig-bis/code/webroot/page/display.cfm:6)
- ID:CFINCLUDE
- MODELO:/home/vagrant/dev/websites/nig-bis/code/webroot/page/display.cfm
- LINHA:6
- TIPO:CFML
- COLUNA:0
Como formatá-lo, então é com você.