#
将字符串进行UBB编码
def ubb_encode(source_str)
source_str.scan(/<img .*?>/) do | v |
if v. match (/src=[ " ' ].*?[ "' ]/) != nil
source_str = source_str.sub(v, ' [img ' + v. match (/src=[ " ' ].*?[ "' ]/)[0] + ' /] ' )
end
end
source_str.scan(/<span[ ]*?.*?>/) do | span |
style = span. match (/style=[ " ']?.*?[ "' ]/).to_s
source_str = source_str.sub(span, ' [span ' + style + ' ] ' )
end
source_str = source_str.gsub(/background-image.*?\)/, '' )
source_str = source_str.gsub( ' </span> ' , ' [/span] ' )
source_str = source_str.gsub(/<strong> | <b>/, ' [b] ' ).gsub(/<\/strong> | <\/b>/, ' [/b] ' )
source_str = source_str.gsub(/<br[ ]*?.*?[\/]?>/, ' [br/] ' )
source_str = source_str.gsub(/<u>/, ' [u] ' ).gsub(/<\/u>/, ' [/u] ' )
source_str = source_str.gsub(/<em> | <i>/, ' [i] ' ).gsub(/<\/em> | <\/i>/, ' [/i] ' )
source_str = source_str.gsub(/<p>/, ' [p] ' ).gsub(/<\/p>/, ' [/p] ' )
return source_str
end
# 将字符串进行UBB解码 不保留HTML代码
def ubb_decode(source_str)
source_str.gsub(/<script.*?>.*?<\/script>/, '' ).gsub(/<.*?>/, '' ).gsub( ' [ ' , ' < ' ).gsub( ' ] ' , ' > ' ).gsub( ' " ' , ' " ' )
end
def ubb_encode(source_str)
source_str.scan(/<img .*?>/) do | v |
if v. match (/src=[ " ' ].*?[ "' ]/) != nil
source_str = source_str.sub(v, ' [img ' + v. match (/src=[ " ' ].*?[ "' ]/)[0] + ' /] ' )
end
end
source_str.scan(/<span[ ]*?.*?>/) do | span |
style = span. match (/style=[ " ']?.*?[ "' ]/).to_s
source_str = source_str.sub(span, ' [span ' + style + ' ] ' )
end
source_str = source_str.gsub(/background-image.*?\)/, '' )
source_str = source_str.gsub( ' </span> ' , ' [/span] ' )
source_str = source_str.gsub(/<strong> | <b>/, ' [b] ' ).gsub(/<\/strong> | <\/b>/, ' [/b] ' )
source_str = source_str.gsub(/<br[ ]*?.*?[\/]?>/, ' [br/] ' )
source_str = source_str.gsub(/<u>/, ' [u] ' ).gsub(/<\/u>/, ' [/u] ' )
source_str = source_str.gsub(/<em> | <i>/, ' [i] ' ).gsub(/<\/em> | <\/i>/, ' [/i] ' )
source_str = source_str.gsub(/<p>/, ' [p] ' ).gsub(/<\/p>/, ' [/p] ' )
return source_str
end
# 将字符串进行UBB解码 不保留HTML代码
def ubb_decode(source_str)
source_str.gsub(/<script.*?>.*?<\/script>/, '' ).gsub(/<.*?>/, '' ).gsub( ' [ ' , ' < ' ).gsub( ' ] ' , ' > ' ).gsub( ' " ' , ' " ' )
end