Skip to content

Commit

Permalink
Fix php/base64 encoder
Browse files Browse the repository at this point in the history
Having things like `'abcde.chr(43).fgh'` doesn't fly, but `'abcde'.chr(43).'fgh'` does.
  • Loading branch information
jvoisin committed Aug 9, 2024
1 parent 233f6dc commit d28fb4c
Showing 1 changed file with 3 additions and 3 deletions.
6 changes: 3 additions & 3 deletions modules/encoders/php/base64.rb
Original file line number Diff line number Diff line change
Expand Up @@ -76,15 +76,15 @@ def encode_block(state, buf)
# Plus characters ('+') in a uri are converted to spaces, so replace
# them with something that PHP will turn into a plus. Slashes cause
# parse errors on the server side, so do the same for them.
b64.gsub!('+', '.chr(43).')
b64.gsub!('/', '.chr(47).')
b64.gsub!('+', "#{quote}.chr(43).#{quote}")
b64.gsub!('/', "#{quote}.chr(47).#{quote}")

state.badchars.each_byte do |byte|
# Last ditch effort, if any of the normal characters used by base64
# are badchars, try to replace them with something that will become
# the appropriate thing on the other side.
if b64.include?(byte.chr)
b64.gsub!(byte.chr, ".chr(#{byte}).")
b64.gsub!(byte.chr, "#{quote}.chr(#{byte}).#{quote}")
end
end

Expand Down

0 comments on commit d28fb4c

Please sign in to comment.