pytanie to jest trudne do podsumowania w tytule pytania
AKTUALIZACJA Stworzyłem JSFiddle, który tworzy zaciemniony ciąg znaków z twoich danych wejściowych w oparciu o litery wyodrębnione z tego pytania: Możesz uzyskać do niego dostęp tutaj , czy może istota byłaby łatwiejsza?
Niedawno natknąłem się na zabawny kawałek zaciemnionego JavaScript w tym profilu, który wygląda tak:
javascript:[[]+1/!1][1^1][1>>1]+({}+[])[1<<1^11>>1]+([]+!!-
[])[1<<1]+[/~/+{}][+!1][-~1<<1]+([]+/-/[(!!1+[])[1>>1]+(!!1
+[])[1<<1^1]+(!1+[])[1|1<<1]+(!!1+[])[1^1]])[1^11<<1]+([,][
~1]+[])[1-~1]+[[]+{}][!1.1%1][11111.1%11.1*111e11|!1]+(/1/+
1/[1<1][1%1])[1^11]+[[],[]+{}][1][+1]+(/<</[1]+[])[1/1.1&1]
Przepraszam, że psuję niespodziankę, ale po ocenie zwraca to:
"I love you" in Chrome
"I lone you" In Firefox
"I lo[e you" in IE10
Sposób, w jaki to działa po rozbiciu, polega na wygenerowaniu serii wiadomości i wyciągnięciu z nich liter w ten sposób (na przykładzie „I”):
[]+1/!1
returns
"Infinity"
then
[[]+1/!1]
creates this array:
["Infinity"]
then
[[]+1/!1][1^1]
Takes the first (1^1 == 0) element of that array
"Infinity"
finally
[[]+1/!1][1^1][1>>1]
Takes the first (1>>1 == 0) char of that string
"I"
Inne generowane ciągi to:
({}+[]) -> "[object Object]" (where the space comes from)
([]+!!-[]) -> "false" (used for it's "l")
[/~/+{}][+!1] -> "/~/[object Object]" (this is used for an "o")
(/<</[1]+[]) -> "undefined"
Byłem zainteresowany znalezieniem zamiennika dla „n” i „[” i wymyśliłem to:
String.fromCharCode(('1'.charCodeAt(0)<<1)+(10<<1))
Który czuję w duchu używania jedynek i zer, ale narusza jeden z bardziej eleganckich aspektów oryginalnego kodu, którym jest pozory, że nie ma nic wspólnego ze stringami. Czy ktoś jeszcze ma pomysł, jak wygenerować „v”, które jest zgodne z oryginalnym zaciemnionym kodem?
Oto kilka dodatkowych informacji, które znaleziono po tym, jak wielu utalentowanych programistów JavaScript przyjrzało się temu dokładniej
Firefox zwraca „I lone you” Z powodu tego wiersza:
([]+/-/[(!!1+[])[1>>1]+(!!1+[])[1<<1^1]+(!1+[])[1|1<<1]+(!!1+[])[1^1]])[1^11<<1]+
[1^11<<1]
wycina z tego określony znak:
([]+/-/[(!!1+[])[1>>1]+(!!1+[])[1<<1^1]+(!1+[])[1|1<<1]+(!!1+[])[1^1]])
Który ocenia to:
"function test() {
[native code]
}"
Co wygląda na to, że możemy mieć nasze „V” !!!
Chrome zwraca „Kocham cię”, ponieważ ten sam kod zwraca to:
"function test() { [native code] }"
Zanim pytanie zostanie zamknięte z powodu wątpliwego połączenia z „prawdziwym problemem programistycznym”, pomyślałem, że dodam podsumowane rozwiązanie, które opiera się na @ Supr's , @ Cory's i @ alpha123's , oto:
alert([[]+1/!1][1^1][1>>1]+({}+[])[1<<1^11>>1]+(
[]+!!-[])[1<<1]+[/~/+{}][+!1][-~1<<1]+[([]+/-/[(
!!1+[])[1>>1]+(!!1+[])[1<<1^1]+(!1+[])[1|1<<1]+(
!!1+[])[1^1]])[1+(1^(11+1+1)<<1)],([]+/-/[(!!1+[
])[1>>1]+(!!1+[])[1<<1^1]+(!1+[])[1|1<<1]+(!!1+[
])[1^1]])[1^11<<1],([]+/-/[(!!1+[])[1>>1]+(!!1+[
])[1<<1^1]+(!1+[])[1|1<<1]+(!!1+[])[1^1]])[1^(11
+1+1)<<1]][((([]+/-/[(!!1+[])[1>>1]+(!!1+[])[1<<
1^1]+(!1+[])[1|1<<1]+(!!1+[])[1^1]])[(1<<1<<1<<1
)+1<<1]==({}+[])[1^1])*1)+((([]+/-/[(!!1+[])[1>>
1]+(!!1+[])[1<<1^1]+(!1+[])[1|1<<1]+(!!1+[])[1^1
]])[(1^11<<1)-1]==({}+[])[1^1])<<1)]+([,][~1]+[]
)[1-~1]+[[]+{}][!1.1%1][11111.1%11.1*111e11|!1]+
(/1/+1/[1<1][1%1])[1^11]+[[],[]+{}][1][+1]+(/<</
[1]+[])[1/1.1&1])
Biorąc pod uwagę złożoność kodu i generowanego przez niego komunikatu, jest to prawie tak, jakby silnik JavaScript mówił, jak wyjątkowo czujesz się w nim :)
źródło
function test() { [native code] }