एक साधारण टीसीपी सर्वर


104

पोर्ट एन पर आने वाले टीसीपी ट्रैफिक के लिए एक प्रोग्राम या फ़ंक्शन लिखें। यह एक सरल सेवा प्रदान करता है: यह आने वाले कनेक्शन और रिटर्न के आईपी पते फ़ील्ड की राशि की गणना करता है।

प्रोग्राम या फंक्शन, पूर्णांक N को तर्कों या स्टडिन से पढ़ता है। यह पोर्ट एन पर आने वाले टीसीपी कनेक्शनों को सुनता है। जब कोई उस पोर्ट से कनेक्ट होता है, तो प्रोग्राम अपने आईपी एड्रेस फ़ील्ड की राशि की गणना करता है और क्लाइंट को नईलाइन के साथ वापस भेजता है और कनेक्शन बंद कर देता है।

  • पोर्ट नंबर N एक वैध पोर्ट है, और 2 10 <N <2 15
  • अनुगामी न्यूलाइन \nया तो हो सकती है या\r\n
  • आप IPv4 या IPv6 का उपयोग कर सकते हैं। चूंकि आईपीवी 6 पते हेक्साडेसिमल रूप में लिखे गए हैं, इसलिए आपको उदाहरण के लिए एक ही प्रारूप में परिणाम प्रदान करना होगा 2001:0db8:0000:0042:0000:8a2e:0370:7334 => 12ecd

यह । मानक नियम और खामियां लागू होती हैं।

उदाहरण

आप अपने सर्वर के साथ चलाते हैं ./server 1234। सर्वर अब चल रहा है और पोर्ट 1234 पर कनेक्शन की प्रतीक्षा कर रहा है। फिर एक क्लाइंट 127.0.0.1आपके सर्वर से कनेक्ट होता है। आपका सर्वर एक सरल गणना करता है: 127+0+0+1 => 128और ग्राहक को परिणाम (नई अनुगामी के साथ) भेजता है 128\n:। फिर सर्वर कनेक्शन बंद कर देता है और अगले ग्राहक की प्रतीक्षा करता है।

लीडरबोर्ड

var QUESTION_ID=76379,OVERRIDE_USER=20569;function answersUrl(e){return"https://api.stackexchange.com/2.2/questions/"+QUESTION_ID+"/answers?page="+e+"&pagesize=100&order=desc&sort=creation&site=codegolf&filter="+ANSWER_FILTER}function commentUrl(e,s){return"https://api.stackexchange.com/2.2/answers/"+s.join(";")+"/comments?page="+e+"&pagesize=100&order=desc&sort=creation&site=codegolf&filter="+COMMENT_FILTER}function getAnswers(){jQuery.ajax({url:answersUrl(answer_page++),method:"get",dataType:"jsonp",crossDomain:!0,success:function(e){answers.push.apply(answers,e.items),answers_hash=[],answer_ids=[],e.items.forEach(function(e){e.comments=[];var s=+e.share_link.match(/\d+/);answer_ids.push(s),answers_hash[s]=e}),e.has_more||(more_answers=!1),comment_page=1,getComments()}})}function getComments(){jQuery.ajax({url:commentUrl(comment_page++,answer_ids),method:"get",dataType:"jsonp",crossDomain:!0,success:function(e){e.items.forEach(function(e){e.owner.user_id===OVERRIDE_USER&&answers_hash[e.post_id].comments.push(e)}),e.has_more?getComments():more_answers?getAnswers():process()}})}function getAuthorName(e){return e.owner.display_name}function process(){var e=[];answers.forEach(function(s){var r=s.body;s.comments.forEach(function(e){OVERRIDE_REG.test(e.body)&&(r="<h1>"+e.body.replace(OVERRIDE_REG,"")+"</h1>")});var a=r.match(SCORE_REG);a&&e.push({user:getAuthorName(s),size:+a[2],language:a[1],link:s.share_link})}),e.sort(function(e,s){var r=e.size,a=s.size;return r-a});var s={},r=1,a=null,n=1;e.forEach(function(e){e.size!=a&&(n=r),a=e.size,++r;var t=jQuery("#answer-template").html();t=t.replace("{{PLACE}}",n+".").replace("{{NAME}}",e.user).replace("{{LANGUAGE}}",e.language).replace("{{SIZE}}",e.size).replace("{{LINK}}",e.link),t=jQuery(t),jQuery("#answers").append(t);var o=e.language;/<a/.test(o)&&(o=jQuery(o).text()),s[o]=s[o]||{lang:e.language,user:e.user,size:e.size,link:e.link}});var t=[];for(var o in s)s.hasOwnProperty(o)&&t.push(s[o]);t.sort(function(e,s){return e.lang>s.lang?1:e.lang<s.lang?-1:0});for(var c=0;c<t.length;++c){var i=jQuery("#language-template").html(),o=t[c];i=i.replace("{{LANGUAGE}}",o.lang).replace("{{NAME}}",o.user).replace("{{SIZE}}",o.size).replace("{{LINK}}",o.link),i=jQuery(i),jQuery("#languages").append(i)}}var ANSWER_FILTER="!t)IWYnsLAZle2tQ3KqrVveCRJfxcRLe",COMMENT_FILTER="!)Q2B_A2kjfAiU78X(md6BoYk",answers=[],answers_hash,answer_ids,answer_page=1,more_answers=!0,comment_page;getAnswers();var SCORE_REG=/<h\d>\s*([^\n,]*[^\s,]),.*?(\d+)(?=[^\n\d<>]*(?:<(?:s>[^\n<>]*<\/s>|[^\n<>]+>)[^\n\d<>]*)*<\/h\d>)/,OVERRIDE_REG=/^Override\s*header:\s*/i;
body{text-align:left!important}#answer-list,#language-list{padding:10px;width:290px;float:left}table thead{font-weight:700}table td{padding:5px}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script> <link rel="stylesheet" type="text/css" href="//cdn.sstatic.net/codegolf/all.css?v=83c949450c8b"> <div id="answer-list"> <h2>Leaderboard</h2> <table class="answer-list"> <thead> <tr><td></td><td>Author</td><td>Language</td><td>Size</td></tr></thead> <tbody id="answers"> </tbody> </table> </div><div id="language-list"> <h2>Winners by Language</h2> <table class="language-list"> <thead> <tr><td>Language</td><td>User</td><td>Score</td></tr></thead> <tbody id="languages"> </tbody> </table> </div><table style="display: none"> <tbody id="answer-template"> <tr><td>{{PLACE}}</td><td>{{NAME}}</td><td>{{LANGUAGE}}</td><td>{{SIZE}}</td><td><a href="{{LINK}}">Link</a></td></tr></tbody> </table> <table style="display: none"> <tbody id="language-template"> <tr><td>{{LANGUAGE}}</td><td>{{NAME}}</td><td>{{SIZE}}</td><td><a href="{{LINK}}">Link</a></td></tr></tbody> </table>


1
क्या इसे inetd / xinetd या समान का उपयोग करने की अनुमति है?
डिजिटल ट्रॉमा

91
मुझे यह पसंद है, क्योंकि यह एक गोल्फ चुनौती है कि गोल्फ भाषा बहुत अच्छे होने की संभावना नहीं है।
18

9
न केवल यह आश्चर्यजनक है कि एक टीसीपी सर्वर जाहिरा तौर पर लिखने के लिए एक बहुत ही आसान कार्यक्रम है, मैं इस तथ्य पर पूरी तरह से तैर रहा हूं कि यह मज़ेदार हो रहा है। मैं बस एक imbecile की तरह FizzBuzz के साथ संघर्ष करने के लिए वापस जाऊँगा।
मंकीज़ियस

17
@isaacg किसी के टीसीपी सर्वर को मैथमेटिका में बनाए जाने से पहले का ही समय है
डाउनगेट

3
@MonkeyZeus निष्पक्ष होने के लिए, आपको यहां कोई अच्छा टीसीपी सर्वर नहीं दिखेगा । एक विश्वसनीय, स्केलेबल टीसीपी सर्वर बनाना जो टीसीपी (और आपके एप्लिकेशन प्रोटोकॉल) की सभी पेचीदगियों को अच्छी तरह से संभालता है, थोड़ा कठिन है: डी हालांकि यह निश्चित रूप से मदद करता है कि प्रोटोकॉल अत्यधिक सरल है - आपको स्ट्रीम पढ़ने की भी आवश्यकता नहीं है, कुछ मैंने देखा है कि कई टीसीपी सर्वरों को तोड़ने के लिए बहुत सारे टूटे हुए हैं: D
Luaan

जवाबों:


57

बैश + netcat + ss +…, 65 60 अक्षर

nc -lp$1 -c'ss src :'$1'|awk \$0=\$5|tr .: +#|bc'
exec $0 $1

एक गंभीर समाधान नहीं था, बस इस संभावना के बारे में उत्सुक था।

करने के लिए धन्यवाद:

  • निंजालawk आधारित फ़िल्टरिंग के सुझाव के लिए (-5 अक्षर)

नमूना रन:

(टर्मिनल 1)

bash-4.3$ ./ip-reduce.sh 8080

(टर्मिनल 2)

bash-4.3$ nc localhost 8080
128

bash-4.3$ telnet localhost 8080
Trying 127.0.0.1...
Connected to localhost.
Escape character is '^]'.
128
Connection closed by foreign host.

उबंटू पर आप प्राप्त कर सकते हैं ncसे netcat पारंपरिक (कोई, netcat-OpenBSD अच्छा नहीं है) और ssसे iproute2


22
आप क्यों कहते हैं कि यह एक गंभीर समाधान नहीं है? जब तक यह उम्मीद के मुताबिक काम करता है, मुझे कोई कारण नहीं दिखता कि इसे गंभीर क्यों न माना जाए। यह इस समय बहुत महत्वपूर्ण अंतर से सबसे छोटा है।
एलेक्स ए।

इसके खिलाफ सबसे बड़ी चिंता @JesseSielaff के साथ चर्चा के दौरान दिखाई दी जब मुझे पता चला कि कॉन्फ़िगर किए गए IPv6 के साथ सिस्टम पर सॉकेट से संबंधित जानकारी अलग-अलग स्वरूपित हो सकती है। इसका परीक्षण करने के लिए ऐसी कोई व्यवस्था नहीं है। जिसके लिए मैं सोच रहा हूं कि क्या इसे सीडब्ल्यू में बदलना सही होगा।
मैनटवर्क

3
युक्ति के बारे में मेरी समझ यह है कि आपको IPv4 या IPv6 का समर्थन करना है , दोनों का नहीं। तो जब तक यह IPv4 के लिए काम करता है, IPv6 का समर्थन नहीं करना चाहिए, इससे कोई फर्क नहीं पड़ेगा।
एलेक्स ए।

1
@AlexA। कम से कम मुझे लगता है कि मेरा सवाल ऐसा कहता है। क्या मुझे इसे स्पष्ट करना चाहिए?
हेंस कारपिला

@HannesKarppila, आपका प्रश्न स्पष्ट है। संभव मुद्दा यह है कि मेरे समाधान के लिए ऑपरेटिंग सिस्टम को चलाने में सक्षम होने के लिए एक विशेष तरीके से कॉन्फ़िगर करने की आवश्यकता हो सकती है। इसलिए मुझे चिंता है क्योंकि यह विफल हो सकता है अगर IPv6 कॉन्फ़िगर किया गया है, भले ही मैं इसे संभालूं या नहीं। कोई व्यक्ति जिसके पास IPv6 कॉन्फ़िगर है, वह इसे निश्चित रूप से बता सकता है ...
manatwork

23

सी #, 284 283 282 278 274 254 बाइट्स

class A{static int Main(string[]a){var b=new System.Net.Sockets.TcpListener(int.Parse(a[0]));b.Start();for(;;){var c=b.AcceptTcpClient();var d=c.Client.LocalEndPoint.Serialize();new System.IO.StreamWriter(c.GetStream()).WriteLine(d[4]+d[5]+d[6]+d[7]);}}}

बेसिक C # TCP सर्वर का क्लासिक उदाहरण। परिक्षण:

टर्मिनल 1:

$ ./Q76379.exe 1029

टर्मिनल 2:

$ telnet localhost 1029
Trying 127.0.0.1...
Connected to localhost.
Escape character is '^]'.
128
Connection closed by foreign host.

फ़ायरफ़ॉक्स:


7
के int Mainबजाय का उपयोग करके आप 1 बाइट बचा सकते हैं void Main। के रूप में कार्यक्रम कभी नहीं देता है संकलक एक returnबयान की आवश्यकता नहीं है ।
राजनागुल

और नहीं, यह लीक नहीं करता है। यह वास्तव में संसाधनों को जारी करने के बारे में बहुत दृढ़ है। इसके अलावा, तर्क Startएक और चरित्र को बचाने के लिए वैकल्पिक है।
लुअन

@ लुआँ हाँ, जो डिबगिंग से बचा हुआ था।
लीजियनममाल 978

इसके अलावा, आप उस usingपर उपयोग कर सकते हैं TcpClient, जो आपको तीन और चरित्रों (उपयोग {}से for) StreamWriterको बचाएगा , और उसी के साथ एक और करना चाहिए।
लुअन

@ Luaan मुझे इसे ठीक से काम करने के लिए स्पष्ट रूप Flushसे StreamWriterकरने की आवश्यकता है ।
लीजनमोनमल 978

22

लिनक्स ELF / x86, 146 बाइट्स

00000000  7f 45 4c 46 01 00 00 00  5a 0e 00 00 5a 5e eb 10  |.ELF....Z...Z^..|
00000010  02 00 03 00 0c 50 eb 10  0c 50 eb 10 04 00 00 00  |.....P...P......|
00000020  5e 53 43 53 52 89 e1 b0  66 3d 20 00 01 00 cd 80  |^SCSR...f= .....|
00000030  97 55 6b ed 0a 01 c5 ac  2c 30 79 f6 43 0f cd 01  |.Uk.....,0y.C...|
00000040  dd 55 89 e1 6a 10 51 6a  10 51 57 89 e1 b0 66 cd  |.U..j.Qj.QW...f.|
00000050  80 43 43 b0 66 cd 80 01  64 24 08 89 e1 43 b0 66  |.CC.f...d$...C.f|
00000060  cd 80 89 c1 93 8d 74 24  1b 99 fd ac 01 c2 e2 fb  |......t$........|
00000070  89 f7 b0 0a aa 91 92 f6  f1 86 c4 04 30 aa 42 c1  |............0.B.|
00000080  e8 08 75 f3 42 89 f9 41  b0 04 cd 80 b0 06 cd 80  |..u.B..A........|
00000090  eb c9                                             |..|
00000092

एक 52-बाइट ईएलएफ हेडर, एक 32-बाइट प्रोग्राम हेडर, 111 बाइट्स प्रोग्राम कोड + 3 बाइट्स कोड के अंदर हेडर के अंदर लंघन के लिए शामिल है।

कैसे छोटे ELF निष्पादनयोग्य बनाने पर जानकारी में पाया जा सकता breadbox के " लिनक्स के लिए वास्तव में Teensy ELF निष्पादन योग्य बनाने पर एक बवंडर ट्यूटोरियल "

लिनक्स / i386 socketcall(2)मल्टीप्लेक्स सिस्टम कॉल का उपयोग करता है , जो ebxविशिष्ट सॉकेट कॉल ( SYS_*मैक्रोस फ्रॉम /usr/include/linux/net.h), और ecxएक पॉइंटर में मूल लाइब्रेरी कॉल के तर्क क्षेत्र में ले जाता है।

निष्पादन योग्य छोटा रखने के लिए कुछ चीजें:

  • यह मानता है कि रजिस्टर एंट्री पर शून्य है, जो लिनक्स करता है, लेकिन ईएलएफ मानक द्वारा इसकी आवश्यकता नहीं है (केवल आवश्यकता यह है कि प्रवेश EDXबिंदुओं पर एक अंतिमकरण funtion (डायनामिक लिंकर द्वारा लोड किए गए निष्पादकों के लिए उपयोगी) या NULL है)।
  • यह लॉन्च पर माना जाता है (आमतौर पर शेल द्वारा) केवल ओपन फाइल डिस्क्रिप्टर 0, 1, और 2 होते हैं। इसका मतलब है कि सुनने वाला सॉकेट fd 3 होगा, और स्वीकृत सॉकेट fd 4 होगा।
  • यह मानता है कि वास्तव में 2 तर्क (सहित argv[0]) हैं।
  • उसी स्टैक स्पेस को कॉल के लिए पुन: उपयोग किया जाता है bind(2), listen(2)और accept(2)
  • पर छोड़ने के लिए phentsizeऔर phnumक्षेत्रों, एक बाइट, prepended है एक में बदल CMPआपरेशन जो लेता है phentsizeऔर phnumएक तत्काल जैसे क्षेत्रों (बेशर्म से चोरी चाल अराजकता गोल्फ में 123 को breadbox के समाधान )।
  • x86 स्ट्रिंग ऑपरेशन LODS(संचायक और वेतन वृद्धि स्रोत सूचकांक में लोड) और STOS(संचायक और वेतन वृद्धि / गंतव्य गंतव्य सूचकांक से स्टोर) लघु कोड के लिए अच्छे हैं।
  • XCHG EAX, regकी तुलना में 1-बाइट है MOV EAX, reg, जो 2 बाइट लेता है।
  • CDQ/CLTD(साइन-इन EAXमें EDX:EAX) का उपयोग EDXरजिस्टर को शून्य करने के लिए 1-बाइट के रूप में किया जा सकता है ।
  • BSWAPलागू करने के लिए उपयोगी है htons()

Nasm स्रोत:

BITS 32                                         ;
                                                ;   ELF HEADER    --   PROGRAM HEADER
; ELF HEADER                                    ; +-------------+
DB 0x7f,'E','L','F'                             ; | magic       |    +--------------------+
                                                ; |             |    |                    |
; PROGRAM HEADERS                               ; |             |    |                    |
DD 1                                            ; |*class   32b | -- | type: PT_LOAD      |
                                                ; |*data   none |    |                    |
                                                ; |*version   0 |    |                    |
                                                ; |*ABI    SysV |    |                    |
DD 0xe5a        ; offset = vaddr & (PAGE_SIZE-1); |*ABI vers    | -- | offset             |
                                                ; |             |    |                    |
entry:  pop     edx     ; edx = 2 (argc)        ; |*PADx7       | -- | vaddr = 0x10eb5e5a |
        pop     esi     ; discard argv[0]       ; |             |    |                    |
        jmp     short skip                      ; |             |    |                    |
DW 2                                            ; | ET_EXEC     | -- |*paddr LO           |
DW 3                                            ; | EM_386      | -- |*paddr HI           |
DD 0x10eb500c                                   ; |*version     | -- | filesz             |
DD 0x10eb500c                                   ; | entry point | -- | memsz              |
DD 4                                            ; | ph offset   | -- | flags: RX          |
                                                ; |             |    |                    |
skip:   pop     esi     ; esi = argv[1]         ; |*sh offset   | -- |*align              |
socket: push    ebx     ; default protocol (0)  ; |             |    |                    |
        inc     ebx                             ; |             |    |                    |
        push    ebx     ; SOCK_STREAM (1)       ; |             |    |                    |
        push    edx     ; AF_INET (2)           ; |*flags       |    +--------------------+
        mov     ecx, esp                        ; |             |
        mov     al, 0x66                        ; |*ehsize      |
DB 0x3d         ; cmp eax,0x10020               ; |             |
DW 32                                           ; | phentsize   |
DW 1                                            ; | phnum       |
                                                ; |             |
        int     0x80    ; socket(2, 1, 0)       ; |*shentsize   |
        xchg    edi, eax; edi = sockfd, eax = 0 ; |*shnum       |
        push    ebp     ; INADDR_ANY            ; |             |
                                                ; |             |
mult:   imul    ebp, 10 ; \_                    ; |*shstrndx    |
        add     ebp, eax; >                     ; |             |
        lodsb           ; >                     ; +-------------+
        sub     al,'0'  ; >
        jns     mult    ; / ebp = atoi(argv[1])                 ;       bind stack frame
                                                                ;    +-----------------------+
endmul: inc     ebx             ; SYS_BIND (2)                  ;    |        INADDR_ANY     |
                                                                ; +->| AF_INET | htons(port) |
        bswap   ebp                                             ; |  +-----------------------+
        add     ebp, ebx        ; AF_INET (2), htons(port)      ; |  |           16          |
        push    ebp                                             ; |  +-----------------------+
                                                                ; |  |         dummy         |
        mov     ecx, esp                                        ; |  +-----------------------+
        push    16              ; addrlen                       ; |  |           16          |
        push    ecx             ; dummy value                   ; |  +-----------------------+
        push    16              ; addrlen                       ; +--|          addr         |
        push    ecx             ; addr                          ;    +-----------------------+
        push    edi             ; sock                          ;    |         sockfd        |
        mov     ecx, esp                                        ;    +-----------------------+
        mov     al, 0x66
        int     0x80            ; bind(sockfd, addr, addrlen)
                                                                ;       accept stack frame
                                                                ;    +-----------------------+
listen: ;mov    byte [esp+8],1                                  ;    |        INADDR_ANY     |
        inc     ebx                                             ; +->| AF_INET | htons(port) |
        inc     ebx             ; SYS_LISTEN (4)                ; |  +-----------------------+
        mov     al, 0x66                                        ; |+>|           16          |
        int     0x80            ; listen(sockfd, backlog)       ; || +-----------------------+
                                                                ; || |         dummy         |
        add     [esp+8], esp                                    ; || +-----------------------+
accept: mov     ecx, esp                                        ; |+-|        &addrlen       |
        inc     ebx             ; SYS_ACCEPT (5)                ; |  +-----------------------+
        mov     al, 0x66                                        ; +--|          addr         |
        int     0x80            ; accept(sockfd, addr, &addrlen);    +-----------------------+
                                                                ;    |         sockfd        |
        mov     ecx, eax        ; ecx = 4                       ;    +-----------------------+
        xchg    ebx, eax        ; ebx = acceptfd, eax = 000000xx

        lea     esi, [esp+27]   ; point to the IP part of struct sockaddr_in
        cdq

        std                     ; reverse direction for string operations
addip:  lodsb                   ; \_
        add     edx, eax        ; > edx = sum of 4 IP bytes
        loop    addip           ; /

        mov     edi, esi        ; reuse struct sockaddr_in as scratch buffer
        mov     al, 10          ; '\n'
        stosb
        xchg    ecx, eax        ; ecx = 10
        xchg    eax, edx        ; edx = 0, eax = sum

divide: div     cl              ; \_
        xchg    al, ah          ; >
        add     al,0x30         ; >
        stosb                   ; > sprintf(scratch, "%d", sum)
        inc     edx             ; >
        shr     eax, 8          ; >
        jnz     divide          ; /

write:  inc     edx             ; ndigits + 1 ('\n')
        mov     ecx, edi
        inc     ecx
        mov     al,4
        int     0x80            ; write(acceptfd, scratch, scratchlen) 
close:  mov     al, 6
        int     0x80            ; close(acceptfd)
        jmp     accept

4
यह जवाब हतप्रभ है।
बिल्ली

16

NodeJS, 146 134 127 बाइट्स

require('http').createServer((q,s)=>s.end(eval(0+q.socket.remoteAddress.replace(/^.*:|\./g,'+'))+'\n')).listen(process.argv[2])

मैं अंत में एक NodeJS उत्तर पोस्ट करने के लिए मिलता है! IPv4 अभी।

नमूना निष्पादन node script.js 1024:। दूसरे टर्मिनल से:

$ curl 127.0.0.1:1024
128

2
मैं अभी 127 बाइट्स गिनता हूं, हालांकि आप इसे 126 तक नीचे ले जा सकते हैं, '\n'जिसमें एक टेम्प्लेट स्ट्रिंग है, जिसमें शाब्दिक न्यूलाइन है।
Mwr247

क्या यह आवश्यकताओं को विफल नहीं करेगा क्योंकि आपका HTTP सर्वर बना रहा है, मेरा मतलब है कि यह तकनीकी रूप से एक टीसीपी सर्वर है, लेकिन क्या आप केवल टीसीपी मॉड्यूल का उपयोग नहीं कर सकते हैं और अपने आप को एक चरित्र बचा सकते हैं?
मेयोरमोनी 19

14

Tcl, 92

  • 1 बाइट @DonalFellows की बदौलत बचा।
proc s {c a p} {puts $c [expr [string map .\ + $a]]
close $c}
socket -server s $argv
vwait f

काफी आत्म-व्याख्यात्मक:

socket -server s $argv तर्कों में निर्दिष्ट पोर्ट पर एक सुनने वाला सॉकेट बनाता है।

हर बार जब कोई नया कनेक्शन आता है, तो proc sउसे चैनल, सोर्स-एड्रेस और सोर्स-पोर्ट को मापदंडों के रूप में कहा जाता है। स्रोत पते के लिए string mapविकल्प , और अंकगणितीय रूप से परिणाम का मूल्यांकन करता है, जो फिर कनेक्शन चैनल पर वापस आ जाता है ।.+exprputsc

vwait आने वाले कनेक्शन की घटनाओं को पकड़ने के लिए एक ईवेंट लूप चलाता है।


निम्नलिखित के लिए @DonalFellows को श्रेय:

यहाँ एक संस्करण है जो IPv6 को संभालता है (आवश्यकता होती है Tcl 8.6; अधिकांश अतिरिक्त लंबाई एक हेक्स प्रतिक्रिया उत्पन्न करने के कारण होती है):

टीसीएल, 109

proc s {c a p} {puts $c [format %x [expr 0x[string map :\ +0x0 $a]]]
close $c}
socket -server s $argv
vwait f

1
का उपयोग करते हुए applyकुछ भी बचाने के लिए प्रतीत नहीं होता है। न ही आप का उपयोग कर सकते हैं tcl::mathop::+ {*}[split $a .]कि थोड़ा लंबा है। न ही आप विकल्प नामों से कुछ भी दाढ़ी कर सकते हैं। लेकिन IPv6 का समर्थन जोड़ना बहुत ही मामूली है, और केवल कोड की कुछ बाइट्स अधिक खर्च होती है (और तब- regsubआधारित दृष्टिकोण बस के रूप में लंबा होता है)।
डोनल फैलो

आह, टीईसीएल / टीईसीएल-डीपी ... उपकरणों का अद्भुत गुच्छा। (90 के दशक में एक प्रोफेसर ने हमें दिखाया कि हम एक नेटवर्क-वितरित एक्सेल (एक ग्रिड के साथ, और फ़ार्मुलों के मूल्यांकन सहित) लिख सकते हैं! सर्वर के लिए (iirc) 4 (छोटी) लाइनों के साथ और ग्राहकों के लिए 5 के साथ कई व्यक्तियों के बीच साझा किया गया। ..
ओलिवियर दुलक

proc s {c a p}क्या आपको वास्तव में उस सभी व्हाट्सएप की आवश्यकता है?
बिल्ली

12

ग्रूवी 133 , 125 , 93 , 89

new ServerSocket(args[0]as int).accept{it<<(it.inetAddress.address as int[]).sum()+"\n"}

IPv4 केवल, शायद।

Ungolfed:

new ServerSocket(args[0]as int).accept{
    it << (it.inetAddress.address as int[]).sum()+"\n"
}

परिक्षण:

$ telnet localhost 9000
Trying 127.0.0.1...
Connected to localhost.
Escape character is '^]'.
128
Connection closed by foreign host.

1
.toInteger()as intऔर s.inetAddress.address*.toInteger()(s.inetAddress.address as int[])। और इसके बाद एक अतिरिक्त जगह है .with
मैनटवर्क

@manatwork thx! अपडेट किया गया।
लीप

9

पायथन 3, 170 166 147 बाइट्स

from socket import*
s=socket()
s.bind(("",int(input())))
s.listen()
while 1:
 c,a=s.accept()
 c.send(b"%d\n"%eval(a[0].replace(".","+"))),c.close()

stdinIPv4 पर ही पोर्ट लेता है । GNU / Linux पर काम करता है (और, मुझे लगता है, अधिकांश अन्य यूनियनों), जो स्वचालित रूप से "" से "0.0.0.0" तक फैलता है, हालांकि विंडोज के बारे में निश्चित नहीं है।


2
आप कई बाइट्स बचा सकते हैं। सबसे पहले, रिक्त स्थान import *और , SOCK_STREAMअनावश्यक हैं। इसके अलावा, भेजने की रेखा को और अधिक कुशलता से लिखा जा सकता है c.send(b"%d\n"%eval(a[0].replace(".","+")))
हनीस करपिला

2
@ हन्नेसकार्पिला ओह, धन्यवाद। रिक्त स्थान के बारे में भूल गया, eval हैक हालांकि बहुत अच्छा है।
शामको

2
AF_INET और SOCK_STREAM सिर्फ स्थिरांक हैं; AF_INET 2 है और SOCK_STREAM 1. है, जैसा कि उल्लेख किया गया है, SOCK_STREAM अनावश्यक है; तो आप का उपयोग करके के बजाय कि छोटा कर सकते हैं s=socket(2)
स्काईलर

1
क्या आप सिर्फ सॉकेट नहीं कर सकते () और इसलिए एक और बाइट बचा सकते हैं?
टेलीफोन

1
आप पायथन 2 का उपयोग करके 10 वर्णों को बचा सकते हैं। फिर, int(input())बन जाता है input()और भेजें भाग बन जाता हैc.send(`eval(a[0].replace(".","+"))`)
ब्लेंडर

9

जावा, 371 368 350 344 333 310 295 282 बाइट्स

golfed

import java.net.*;class A{public static void main(String[]n)throws Exception{ServerSocket s=new ServerSocket(Integer.decode(n[0]));for(;;){try(Socket a=s.accept()){byte[]c=a.getInetAddress().getAddress();new java.io.PrintStream(a.getOutputStream()).println(c[0]+c[1]+c[2]+c[3]);}}}}

Ungolfed

import java.net.*;

class A {
    public static void main(String[] n) throws Exception {
        ServerSocket s = new ServerSocket(Integer.decode(n[0]));
        for (;;) {
            try (Socket a = s.accept()) {
                byte[] c = a.getInetAddress().getAddress();
                new java.io.PrintStream(a.getOutputStream()).println(c[0] + c[1] + c[2] + c[3]);
            }
        }
    }
}

उत्पादन

mallard@steamroller:~$ telnet localhost 8888
Trying 127.0.0.1...
Connected to localhost.
Escape character is '^]'.
128
Connection closed by foreign host.

1
निकालें int k=और कश्मीर को सभी सी चीजों से बदल दें Integer.toString(k)। कुछ बाइट्स बचाने के लिए।
जाइंटट्री

1
जावस बाइट ने निश्चित रूप से १
२.१६.1.२.१ के

1
कुछ और बाइट हासिल interfaceकरने के लिए बदलावclass
ortis

2
के a.getOutputStream().write((c[0] + c[1] + c[2] + c[3]+"\n").getBytes());बजाय का उपयोग करेंnew DataOutputStream(a.getOutputStream()).writeBytes(c[0] + c[1] + c[2] + c[3] + "\n")
ortis

3
try(Socket a=...){}से छोटा नहीं है a.close();? जावा 7 की आवश्यकता है, लेकिन बाइट्स प्राप्त कर सकते हैं।
ओलिवियर ग्राएगोइरे

8

PowerShell v2 +, 303 268 257 227 बाइट्स

nal n new-object;($l=n Net.Sockets.TcpListener($args[0])).Start()
for(){($w=n IO.StreamWriter(($c=$l.AcceptTcpClient()).GetStream())).Write((([Net.IPEndPoint]$c.Client.RemoteEndPoint).Address-replace"\.",'+'|iex))
$w.Dispose()}

मैट के लिए 35 बाइट्स का धन्यवाद सहेजा गया ... अन्य 11 बाइट्स को अलियासिंग New-Objectऔर माइनर ट्वीक्स द्वारा सहेजा गया ... anyआईपी ​​पते के बजाय लोकलहोस्ट का उपयोग करके 30 से अधिक बाइट्स सहेजे गए और मूल रूप से निर्दिष्ट के रूप में निरंतर उपयोग के लिए खाते में सही हो गए और मैं चूक गया।

वास्तव में C # उत्तर के समान है , क्योंकि यह .NET अंतर्निहित दोनों है। हम PowerShell की रिटर्निंग कार्यक्षमता का लाभ उठाने में सक्षम होने के कारण C (उत्तर में, और हमारे तुरंत घोषणा / असाइनमेंट में और फिर तुरंत कॉल कर रहे हैं) पर कुछ बाइट्स बचाते हैं, लेकिन हम योग को तैयार करने की आवश्यकता के द्वारा एक बहुत कुछ खो देते हैं। । यह तथ्य कि हमें थोड़े छोटे वर्ग के नाम / कॉल मिले हैं, वास्तव में यही कारण है कि यह उत्तर C # धड़क रहा है।

व्याख्या

बाद में फिर से टाइप करने के लिए हम पहले New-Alias( nalउपनाम के साथ ) बनाते हैं New-Object। शेष पहली पंक्ति एक टीसीपी श्रोता को स्थापित कर रही है। हम $args[0]एक नया System.Net.Sockets.TcpListener, बनाने के लिए इनपुट के रूप में कमांड-लाइन पास करते हैं $l। उस वस्तु को पैरेन्स में एनकैप्सुलेट किया जाता है और तुरंत .Start()इसे सॉकेट खोलने के लिए सक्रिय रूप से बुलाया जाता है ।

एक अनंत forलूप में प्रवेश करते हुए , हम फिर अपने श्रोता $lको अवरुद्ध करने के लिए सेट करते हैं AcceptTcpClient()जिसके साथ एक कनेक्शन की प्रतीक्षा होगी। उस कनेक्शन का संदर्भ (एक बार जब यह बना होता है), संग्रहित किया जाता है $c, Parens में समझाया जाता है, और तुरंत GetStream()डेटास्ट्रीम प्राप्त करने के लिए कहा जाता है। उस डाटैस्ट्रीम को नए System.IO.StreamWriterकंस्ट्रक्टर के पास भेज दिया जाता है $w, इसलिए हम इसमें फेरबदल कर सकते हैं। उस कंस्ट्रक्टर को खुद परेंस में इनकैप्सुलेट किया जाता है और तुरंत कॉल किया जाता है Write(...)

Write(...)कॉल के अंदर , हम अपने ग्राहक को संभालते हैं $cऔर ग्राहक की RemoteEndPointसंपत्ति प्राप्त करते हैं। यह एकमात्र तरीका है (जो मैंने अब तक पाया है) दूरस्थ आईपी पता प्राप्त करने के लिए। अगला हमें फिर से कास्ट करने की आवश्यकता है [System.Net.IPEndPoint]ताकि एक वस्तु के रूप में इसे सही ढंग से स्वरूपित किया जाए, जो कि Parens में एनकैप्सुलेट करता है, और बस .Addressसंपत्ति खींचता है । हम तब -replaceप्लस साइन्स के साथ शाब्दिक अवधि, फिर हमारे समन को प्राप्त करने के लिए इसे Invoke-Expression(इसी तरह eval) पाइप करते हैं ।

IO लिखने के बाद, हमें .Dispose()यह सुनिश्चित करने के लिए कॉल करना होगा कि डेटास्ट्रीम क्लाइंट को फ्लश किया गया और बंद हो गया। टीसीपी सर्वर क्लाइंट कनेक्शन को बिना किसी चेतावनी के छोड़ देता है, इसलिए उपयोग किए गए क्लाइंट के आधार पर यह इस बिंदु पर थोड़ी देर के लिए लटका रह सकता है। यह फिर forकनेक्शन को ठीक से बंद किए बिना लूप के माध्यम से जारी रहता है । इसका मतलब यह भी है कि यह पागलों की तरह मेमोरी और सिस्टम हैंडल लीक करता है, लेकिन हम इस बारे में परवाह नहीं करते हैं, है ना? हालाँकि, सर्वर को चलाने के दौरान आपको प्रक्रिया को मारने के लिए टास्क मैनेजर का उपयोग करना पड़ सकता है। : डी

इसके अलावा IPv4 केवल, क्योंकि बार बार शानदार तरीके से IPv6 पते को संभालने की कोशिश की जाती है, क्योंकि पार्स के :लिए एक मान्य बीजीय संचालक नहीं है iex


2
"लीक्स मेमोरी और सिस्टम पागलों की तरह हैंडल करता है" क्या, आपके पास free()उनके बाद क्या है? delete[], शायद? : पी
बिल्ली

8
@ टीएसी हाँ, वहाँ एक पूरी नींद .close()और .dispose()तरीके हैं जिन्हें हम यहाँ नहीं बुला रहे हैं जिससे कोड रिव्यू पर लोग फिट हो सकें।
AdmBorkBork

ओह, पीएस GC'd नहीं है? या जीसी रिफकाउंटिंग करता है और स्कोप-एनालिसिस नहीं?
बिल्ली

@ टैक हां, PowerShell में अंतर्निहित .NET सिस्टम के लिए कचरा संग्रह है। लेकिन, आप इस स्क्रिप्ट को कैसे कॉल या लीवरेज कर रहे हैं, इसके आधार पर, आप पाइपलाइन में इस एक लीक मेमोरी की तरह बग्स में दौड़ सकते हैं । उपरोक्त कोड भी थ्रेड-सुरक्षित नहीं है, और इसलिए हम इसके साथ GC समस्याओं में भाग सकते हैं, क्योंकि हम स्पष्ट रूप से सॉकेट बंद नहीं कर रहे हैं।
AdmBorkBork

1
परीक्षण में मुझे यह काम करने के लिए नहीं मिल सकता है, संभवतः फ़ायरवॉल मुद्दों के कारण जो मुझे ठीक करने का मन नहीं करता है, इसलिए मुझे यकीन नहीं हो सकता है लेकिन ..... मुझे लगता है कि आप "सिस्टम" को सबसे ज्यादा छोड़ सकते हैं यदि सभी प्रकार की जातियां नहीं हैं। आपके पास वहाँ है: [Net.ipaddress]::Anyकाम करता है।
मैट

7

PHP, 161 (56)

यह मेरी यहां पहली पोस्ट है। मुझे आशा है कि यह सही हो जाता है :)

<?php $s=socket_create_listen($argv[1]);while($c=socket_accept($s)){socket_getpeername($c,$r);socket_write($c,array_sum(explode('.',$r))."\n");socket_close($c);}

Ungolfed:

<?php 
    $s = socket_create_listen($argv[1]); //Create socket
    while( $c = socket_accept($s) ) { // Loop accepting new connections
        socket_getpeername($c, $r); // Get IP address in $r
        socket_write($c, array_sum(explode('.', $r))."\n"); //Calculate sum
        socket_close($c); //Close connection and wait for next one
    }

टर्मिनल:

$ php test.php 8080 &
$ telnet localhost 8080
Trying 127.0.0.1...
Connected to localhost.
Escape character is '^]'.
128
Connection closed by foreign host.

यह केवल IPV4 के लिए काम करता है

संपादित करें : मैंने अभी देखा कि php मूल सर्वर का समर्थन करता है:
मैंने मूल वर्ण गणना से चिपके रहने का निर्णय लिया जब तक कि किसी ने पुष्टि नहीं की कि निम्नलिखित की अनुमति है :)

test2.php: (संभव 56-बाइट समाधान)

<?=array_sum(explode('.',$_SERVER['REMOTE_ADDR']))."\n";

और उसके बाद सेवा शुरू करें:

php -S localhost:8080 test2.php

ग्राहक के रूप में क्रोम स्क्रीनशॉट

2 संपादित करें: ग्राहक के रूप में wget

$ wget -qO- localhost:8080
128

मुझे पता है कि नियम कहते हैं: "प्रोग्राम या फंक्शन, पूर्णांक या स्टड से पूर्णांक N को पढ़ता है", लेकिन क्या यह ठीक है यदि इस मामले में प्रोग्राम स्वयं php है? या php में अंतर्निहित सर्वर का उपयोग कर माना जाता है?
मिकेल

प्रोग्रामिंग पहेलियाँ और कोड गोल्फ में आपका स्वागत है! आपका 161-बाइट समाधान बहुत अच्छा लग रहा है। क्या 56-बाइट समाधान का आपने उल्लेख किया है test2.php? यदि हां, तो मुझे लगता है कि आपको ओपी से पूछना होगा कि क्या वे इस चुनौती के लिए उस तरह के अंतर्निहित स्वीकार्य पर विचार करेंगे। यह एक बचाव का रास्ता नहीं है।
एलेक्स ए।

मैं कहूंगा, एक अंतर्निहित टीसीपी सर्वर का उपयोग स्वीकार्य होगा, लेकिन इस मामले में हम एक बिल्ट HTTP सर्वर के बारे में बात करते हैं । तो 56 बाइट समाधान 1) कुछ भी नहीं करता है अगर ग्राहक केवल जोड़ता है और कुछ भी नहीं भेजता है; 2) केवल वापस भेजता है "[बुध मार्च 30 10:15:02 2016] 127.0.0.1:47974 अमान्य अनुरोध (विकृत HTTP अनुरोध)" परीक्षण के बिना चल रहा है। यदि ग्राहक उदाहरण के लिए भेजता है तो "फू"; 3) क्लाइंट वास्तविक HTTP अनुरोध भेजने के मामले में वास्तविक आवश्यक प्रतिक्रिया से पहले HTTP प्रतिक्रिया हेडर का पूरा सेट भेजता है।
मैनावर्क

@ एलेक्स ए धन्यवाद और हाँ, 56-बाइट समाधान test2.php के तहत है :)
मिकेल

@manatwork आप सही हैं लेकिन मैं सोच रहा था कि क्लाइंट इस कार्य में स्पष्ट रूप से निर्दिष्ट नहीं है। तो क्या क्लाइंट के रूप में "wget ​​-qO- लोकलहोस्ट: 8080" जैसे ब्राउज़र या इससे भी अधिक सरल चीज़ का उपयोग करना ठीक है?
मिकेल

7

गो , ३५ ९ ३११

यह गो में मेरा पहला कार्यक्रम है - इसने मुझे एक चीज़ की खोज करने की अनुमति दी: यह निश्चित रूप से एक अच्छी गोल्फिंग भाषा नहीं है!

(कुडोस @ @veve ने सबसे ज्यादा गोल्फ किसने किया!)

package main
import(n"net";t"strings";r"strconv";x"regexp";"os")
func main(){l,_:=n.Listen("tcp",":"+os.Args[1])
for{c,_:=l.Accept();var s int
for _,i:=range t.Split(x.MustCompile(":[0-9]+$").ReplaceAllLiteralString(c.RemoteAddr().String(),""),"."){
n,_:=r.Atoi(i);s=s+n};c.Write([]byte(r.Itoa(s)));c.Close()}}

2
लेकिन यह सुनिश्चित है कि एक tcp सर्वर बनाने के लिए एक अच्छी भाषा है!
नुमेरी

1
अजीब, परिणाम 360 जब मैं 192.168.0.67 से कनेक्ट हो रही है, बजाय 427
स्टीव

3
आप कुछ बाइट्स को बचाने के लिए स्ट्रिंग्स + स्ट्रैन्क पैकेज को नाम दे सकते हैं। उदाहरण ऐसा "strings"हो जाता s "strings"है कि बाद में strings.Splitबस बन जाता है s.Split
चरण

1
कुछ और बाइट्स बंद मुंडा pastebin.com/HY84sazE - थोड़ा अधिक देखने के लिए शुरू कर अब "golfed"
स्टीव

2
यदि आप import(."pkgname")सभी कार्यों का उपयोग करते हैं तो वर्तमान नामस्थान पर आयात किया जाएगा, फिर आप उपसर्ग छोड़ सकते हैं। जैसे। import ."fmt"; Println("foo") यदि आप regex के बजाय पते को पार्स करने के Sscanfलिए fmtपैकेज से उपयोग करते हैं , तो यह आपको Fprintlnआयात करने के बजाय कुल वापस करने के लिए होने का अच्छा बोनस देते हुए, आपको कुछ और बाइट्स बचाएगा strconv
क्रिस्टोफ़र सल्ल-स्टॉरगार्ड

7

आम लिस्प, 110 बाइट्स

(use-package'usocket)(lambda(p)(socket-server"localhost"p(lambda(u)(format u"~D~%"(reduce'+ *remote-host*)))))

विवरण

(use-package 'usocket)

(lambda (port)

  ;; create server with event-loop
  (socket-server "localhost"
                 port

                 ;; tcp-handler
                 (lambda (stream)
                   ;; format to stream to client
                   (format stream
                           "~D~%"
                           ;; add all elements of the host,
                           ;; a vector of 4 integers
                           (reduce #'+ *remote-host*))

                   ;; client connection is closed automatically
                   ;; when exiting this function                     
                 )))

2
आम लिथ के लिए याय!
बिल्ली

6

क्यू, 88 बाइट्स

system raze"p ",1_.z.x;.z.pg:{(string sum"i"$0x0 vs .z.a),"\n"};.z.ph:{.h.hy[`;.z.pg[]]}
  • system raze"p ",1_.z.x: दूसरी कमांड-लाइन तर्क लेता है (पहला स्क्रिप्ट / फ़ाइल के रूप में व्याख्या नहीं करने के "-"लिए कहता है ) और इसके साथ एक पोर्ट ( ) खोलता है। qN"p "
    • नोट: कॉलिंग q -p Nपोर्ट को Nस्वचालित रूप से सेट करता है , लेकिन चूंकि प्रश्न यह सुझाव देता है कि Nनिष्पादन योग्य के बजाय प्रोग्राम का एक तर्क होना चाहिए, मैं लंबा रास्ता तय कर चुका हूं।
  • .z.pgआने वाले अनुरोधों को संभालने वाले फ़ंक्शन के अंदर , .z.aआईपी ​​पते को 32-बिट पूर्णांक के रूप में रखता है।
    • "i"$0x0 vsइसे अपने पूर्णांक 'घटकों' में विभाजित sumकरता है , और योग करता है।
    • अंतिम, stringसंख्यात्मक परिणाम और "\n"ग्राहक को वापस करने के लिए इसे करने के लिए अपील।
  • .z.ph HTTP GET अनुरोधों के लिए एक और कार्य है, स्ट्रिंग आउटपुट को वैध HTTP प्रतिक्रिया में बदलने के लिए अतिरिक्त हैंडलिंग के साथ।

डेमो - सर्वर:

c:\q\w32>q - 1234
KDB+ 3.3 2015.11.03 Copyright (C) 1993-2015 Kx Systems
w32/ 4()core ... NONEXPIRE

Welcome to kdb+ 32bit edition
q)system raze"p ",1_.z.x;.z.pg:{(string sum"i"$0x0 vs .z.a),"\n"};.z.ph:{.h.hy[`;.z.pg[]]}
q)

डेमो - ग्राहक (दूसरे qसत्र से चल रहा है 127.0.0.1):

q)(hopen `::1234)""
"128\n"

डेमो - क्लाइंट (से curl):

$ curl localhost:1234
128

$

6

लाइवस्क्रिप्ट, 107 105 बाइट्स

(require \http)createServer(->&1.end((.reduce (+))<|it.connection.remoteAddress/\.))listen process.argv.0

जोड़ने के लिए ज्यादा कुछ नहीं है, यह सिर्फ मूल NodeJS सामान है। &1(दूसरे तर्क) के लिए शैली बिंदु , <|(F # पाइपिंग, $हास्केल में akin) और बायोप: (+)एलएस में हास्केल में ऑपरेटर वर्गों की तरह है: एक करी बाइनरी फ़ंक्शन (जो अपने ऑपरेंड जोड़ता है)। थोड़ा गंदा भी:, /यदि इसके दाईं ओर एक शाब्दिक स्ट्रिंग दिया जाता है , तो विभाजन होगा।


5

पर्ल, 141 132 + 1 = 133 बाइट्स

golfed

$s=new IO::Socket::INET LocalPort=><>,Listen=>5,Reuse=>1;{$c=$s->accept;$_=$c->peerhost;y/./+/;$c->send(eval.$/);shutdown $c,1;redo}

Ungolfed

# listen on tcp port obtained from stdin
$s=new IO::Socket::INET(LocalPort=> <>,
                        Listen   => 5,
                        Reuse    => 1);

{
    # accept connection
    $c=$s->accept();

    # get the ip address
    $_=$c->peerhost();

    # replace dots with plus
    y/./+/;

    # send the evaluated version back, with a newline
    $c->send(eval . $/);

    # close
    shutdown($c,1);

    redo;
}

उदाहरण

$ echo 7777|perl -MIO::Socket::INET -e'$s=new IO::Socket::INET LocalPort=><>,Listen=>5,Reuse=>1;{$c=$s->accept;$_=$c->peerhost;y/./+/;$c->send(eval.$/);shutdown $c,1;redo}'

$ telnet 127.0.0.1 7777
Trying 127.0.0.1...
Connected to 127.0.0.1.
Escape character is '^]'.
128
Connection closed by foreign host.
$

क्या आपको यकीन है कि यह सही है? मुझे सर्वर के टर्मिनल में मुद्रित राशि मिलती है, क्लाइंट की नहीं। वैसे भी, आप सभी कोष्ठक को हटा सकते हैं और s/\./+/g→ बदल सकते हैं y/./+/

आह, गलतफहमी..इसके अनुसार संशोधित करें और अपने अच्छे y / सुझाव को शामिल करें।
स्टीव

1
while(1){…}user130144 के महान टिप के{…;redo} अनुसार । और कॉल को छोड़कर , अन्य सभी कोष्ठक अनावश्यक हैं। ->send()
मैनटवर्क

4

पायथन 2, 180 बाइट्स

from SocketServer import*
TCPServer(('',input()),type('',(BaseRequestHandler,set),{'handle':lambda s:s.request.send(`eval(s.client_address[0].replace('.','+'))`)})).serve_forever()

स्टड पर पोर्ट लेता है।


4

NodeJS (ES6), 129 118 107 बाइट्स

require('net').createServer(c=>c.end(eval(c.remoteAddress.replace(/\./g,'+'))+`
`)).listen(process.argv[2])

IPv4 के लिए काम करता है। ऐसे दोड़ोnode server.js <port>


वास्तव में अगर सर्वर IPv6 (उदाहरण के लिए, मेरा स्वचालित रूप से करता है) का उपयोग कर रहा है, c.remoteAddressतब से काम नहीं करेगा ::ffff:127.0.0.1। (मैंने नोड v5.9.1 पर परीक्षण किया)।
Frxstrem

इसके अलावा, आपके पास एक अनुगामी न्यूलाइन नहीं है, जो आपके स्कोर को 2 बाइट्स बढ़ा दे।
Frxstrem

@Frxstrem वूप्स, भूल गए कि न्यूलाइन। केवल 1 बाइट जोड़ता है, हालांकि टेम्पलेट स्ट्रिंग्स के लिए धन्यवाद। आईपी ​​परिवार के बारे में: .listen()पहले IPv4 के लिए डिफ़ॉल्ट रूप से उपयोग किया जाता है, लेकिन यह या तो बग या डिज़ाइन से लगता है कि यह बदल गया है। जब IPv6 होस्ट मशीन पर अक्षम हो जाता है, तो सबमिशन नोड के नए संस्करणों पर ठीक से काम करेगा।
Mwr247

4

जाओ, 211 बाइट्स

package main
import(."fmt"
."net"
"os")
func main(){s,_:=Listen("tcp4",":"+os.Args[1])
for{c,_:=s.Accept()
var a,b,d,e int
Sscanf(Sprint(c.RemoteAddr()),"%d.%d.%d.%d",&a,&b,&d,&e)
Fprintln(c,a+b+d+e)
c.Close()}}

शायद आगे गोल्फ हो सकता है, मैं उदाहरण के लिए आईपी एड्रेस को पार्स करने के तरीके से पूरी तरह से संतुष्ट नहीं हूं, यह एक भयानक हैक की तरह दिखता है।

IPv4 पर दिए गए पोर्ट पर तर्क के रूप में सुनता है।


4

पॉवरशेल, 208 206 192 152 बाइट्स

($t=[net.sockets.tcplistener]$args[0]).start();for(){($z=$t.acceptsocket()).sen‌d([char[]]"$($z.remoteendpoint.address-replace"\.","+"|iex)");$z.close()}

संस्करण जानकारी:

Name                           Value
----                           -----
PSVersion                      4.0
WSManStackVersion              3.0
SerializationVersion           1.1.0.1
CLRVersion                     4.0.30319.34209
BuildVersion                   6.3.9600.17400
PSCompatibleVersions           {1.0, 2.0, 3.0, 4.0}
PSRemotingProtocolVersion      2.2

मुझे 14 बाइट्स बचाने के लिए टिम्मीड का धन्यवाद!

मुझे 40 बाइट बचाने के लिए TessellatingHeckler का बहुत बड़ा धन्यवाद


@TimmyD आह उफ़ मैंने याद किया कि यह आवश्यक था ... अब तय किया गया
नच

इन तरीकों में से एक इनपुट लेने की अनुमति है। मुझे लगता है कि यह विशेष प्रश्न यह निर्दिष्ट नहीं करता है कि अनुमति दी गई है, लेकिन यह एक सामान्य कोड-गोल्फ चीज़ है जो मुझे लगता है कि PowerShell के लिए गणना करनी चाहिए। यह दुर्भाग्य से बाश से अलग है कि अगर यह कोई भी प्रदान नहीं किया गया है तो यह स्टड पर इनपुट की प्रतीक्षा नहीं करता है।
नाच

काफी उचित। फिर से तय किया
Nacht

ठीक है, अब कुछ ($t=new-object net.sockets.tcplistener($args[0])).start();for(){($z=$t.acceptsocket()).send(($x=[byte[]][char[]](""+($z.remoteendpoint.address-replace"\.","+"|iex))+32),$x.count,0);$z.close()}
गोल्फों के लिए

1
मुझे लगता है कि आप इसे 152 तक गिरा सकते हैं - नई-वस्तु को छोड़ सकते हैं और सीधे डाल सकते हैं, बाइट सरणी रूपांतरण को छोड़ सकते हैं और एक स्ट्रिंग डाली को अलग तरीके से कर सकते हैं, $ x को बिल्कुल स्टोर न करें और भेजने के लिए शेष पैरामीटर ड्रॉप करें (), और इसे बन जाता है ($t=[net.sockets.tcplistener]$args[0]).start();for(){($z=$t.acceptsocket()).send([char[]]"$($z.remoteendpoint.address-replace"\.","+"|iex)");$z.close()}- जिसे मैंने केवल नेटकैट कनेक्ट करने के साथ जल्दी परीक्षण किया है, लेकिन यह वही काम करता है - वैसे भी लोकलहोस्ट से कनेक्ट करना।
TessellatingHeckler

4

8086 मशीन कोड (16-बिट डॉस), 163 156 148 148 142 बाइट्स

00000000  31 c0 bb 0a 00 31 c9 be  81 00 bf 80 00 8a 0d 01  |1....1..........|
00000010  cf 46 8a 0c 80 e9 30 f7  e3 00 c8 39 fe 72 f2 89  |.F....0....9.r..|
00000020  c3 89 c1 b8 01 10 ba ff  ff 31 f6 31 ff cd 61 53  |.........1.1..aS|
00000030  b8 00 12 bf 80 00 b9 01  00 ba ff ff cd 61 b8 00  |.............a..|
00000040  14 cd 61 31 c0 bb 0a 00  83 c7 06 8d 4d 04 26 02  |..a1........M.&.|
00000050  05 80 d4 00 47 39 cf 72  f5 bf 84 00 b9 80 00 bb  |....G9.r........|
00000060  0a 00 4f 31 d2 f7 f3 80  c2 30 88 15 39 cf 77 f2  |..O1.....0..9.w.|
00000070  1e 07 b8 0e 13 5b bf 80  00 b9 04 00 ba ff ff cd  |.....[..........|
00000080  61 b8 00 11 ba 01 00 cd  61 b8 00 4c cd 21        |a.......a..L.!|
0000008e

समतुल्य विधानसभा कोड:

org 0x100
tcp equ 0x61    ; NTCPDRV interrupt

    xor ax,ax
    mov bx,10
    xor cx,cx
    mov si,0x81     ; [ds:81]-[ds:FF] = command line args
    mov di,0x80     ; [ds:80] = strlen(args)
    mov cl,[di]
    add di,cx

@@: inc si
    mov cl,[si]     ; get character
    sub cl,'0'      ; convert char to int
    mul bx          ; ax *= 10
    add al,cl
    cmp si,di
    jb @b
    ; now ax = port number

    mov bx,ax       ; source port (leaving this 0 doesn't work?)
    mov cx,ax       ; dest port
    mov ax,0x1001   ; open TCP socket for listening
    mov dx,-1       ; infinite timeout
    xor si,si       ; any dest IP
    xor di,di
    int tcp
    ; ^ I think this call should block until a connection is established, but apparently it doesn't.

    push bx         ; bx = socket handle, save it for later

    mov ax,0x1200   ; read from socket
    mov di,0x80     ; es:di = buffer (just reuse argument area to save space)
    mov cx,1        ; one byte
    mov dx,-1
    int tcp         ; this will block until a client connects and sends one byte

    mov ax,0x1400   ; get TCP session status, bx=handle
    int tcp
    ; now es:di points to a struct containing the source/dest IP addresses and ports
    ; the docs say it's two dwords for each IP address, then two bytes for "ip_prot" and "active" (whatever that means)
    ; ...but actually each IP address is followed by the port number (one word)

    xor ax,ax
    mov bx,10
    add di,6        ; [es:di+6] = client IP
    lea cx,[di+4]
@@: add al,[es:di]  ; add all bytes together
    adc ah,0
    inc di
    cmp di,cx
    jb @b
    ; now ax contains the IP address sum

    mov di,0x84     ; recycle arguments area again
    mov cx,0x80
    mov bx,10
@@: dec di
    xor dx,dx
    div bx          ; dl = ax mod 10
    add dl,'0'      ; convert int to char
    mov [di],dl
    cmp di,cx
    ja @b
    ; now [ds:80]-[ds:83] contains an ascii representation of the IP address sum

    push ds
    pop es
    mov ax,0x130e   ; send data with newline, wait for ack
    pop bx          ; socket handle
    mov di,0x80     ; es:di = data
    mov cx,4        ; sizeof data
    mov dx,-1
    int tcp

    mov ax,0x1100   ; close TCP socket
    mov dx,1
    int tcp

    mov ax,0x4c00
    int 0x21

यह मान लिया गया ntcpdrvहै INT 0x61(और किसी भी उपयुक्त पैकेट ड्राइवर पर 0x60)। के साथ संकलित करें fasm tcpserv.asm

हालांकि इसके कुछ मुद्दे हैं:

  • यह जाँच नहीं करता है कि क्या तर्क एक वैध पोर्ट नंबर है, या यदि यह एक नंबर भी है।
  • ग्राहक को कम से कम एक बाइट भेजना होगा, क्योंकि मुझे यह बताने का कोई अन्य तरीका नहीं मिल सकता है कि क्या ग्राहक जुड़ा है।
  • यह केवल एक बार काम करता है, और दूसरे प्रयास में लटका रहता है। रिबूट के बाद फिर से काम करता है।
  • लौटाया गया मान शून्य-गद्देदार है।
  • यह मेरी बहुत पहले कोड वाली गोल्फ प्रविष्टि है, और मेरी बहुत पहले 8086 की एसएसएम प्रोग्राम भी है। मुझे यकीन है कि आगे इसे सुधारने के तरीके हैं।

1
आप बस 148 बाइट्स के लिए संकलित आउटपुट का एक हेक्सडंप पोस्ट कर सकते हैं
बिल्ली

क्या इसकी अनुमति है? यह इस प्रविष्टि को और अधिक प्रतिस्पर्धी बना देगा ...
user5434231

1
ठीक है, मैंने मशीन कोड में प्रविष्टि बदल दी है। इसके xor r,rबजाय का उपयोग करके बंद कुछ और बाइट्स मुंडा mov r,0
user5434231

1
मैंने इसे एक डॉस मशीन पर लिखा था जहाँ नई कहानियाँ हैं CR LF, इसलिए मैं बस उसी के साथ गया था। किसी भी तरह से यह asm आकार को गिनने के लिए थोड़े व्यर्थ है, हो सकता है कि वह इसे थोड़ा साफ कर दे और कुछ टिप्पणियां जोड़ दे।
user5434231

1
यहाँ भी यही होना चाहिए, और यह काम करता है; int 0x61में एक यादृच्छिक स्थानीय पोर्ट लौटाता है ax। लेकिन यह सुनने वाले आईपी को कुछ कचरा संख्या ( 4.2.0.0iirc) में भी बदल देता है
user5434231

3

हास्केल, 216 बाइट्स

"नेटवर्क-सरल" पैकेज ( cabal install network-simple) का उपयोग करना । -XOverloadedStrings -XNoMonomorphismRestrictionकाम करने के लिए भाषा एक्सटेंशन ( ) की एक जोड़ी की जरूरत है ।

import Network.Simple.TCP(serve)
import Network.Socket
import Data.Bits
main=getLine>>= \n->serve"*"n p
p(s,(SockAddrInet _ h))=()<$(send s$(show$sum$w h 24)++"\n")
m=255
w h 0=[h.&.m]
w h n=h`shiftR`n.&.m:(w h$n-8)

संभावित सरलीकरण के एक जोड़े हैं, जिसमें wसूची के बजाय सीधे राशि वापस करने के लिए फ़ंक्शन को बदलना , और प्रोग्राम के बजाय फ़ंक्शन का उपयोग करना है ताकि पोर्ट नंबर को एक तर्क के रूप में निर्दिष्ट किया जा सके। मुझे नहीं लगता कि यह आकार को बहुत कम करेगा, हालांकि। 20 बाइट्स शायद?


अच्छा! यकीन है कि तुम अब भी नाम बदलकर से कुछ बाइट्स दाढ़ी कर सकते हैं wकरने के लिए #है, तो w h nहो जाता है h#nउपयोग प्रति 2 बाइट्स की एक बचत के लिए।
एक्टरक्लाविलिस

3

मम्प्स, 114 115 बाइट्स

golfed:

R P F{S J=0,I="|TCP|1" O I:(:P) U I R K F K=1:1:4{S J=J+$P(##class(%SYSTEM.TCPDevice).PeerAddr(),".",K)} W J,! C I}

Ungolfed:

R P             ; Read Port # from STDIN ;
  F{            ; Loop over everything;
  S J=0,        ; Initial IP segment total
  I="|TCP|1"    ; TCP device
  O I:(:P)      ; Open the TCP device, port from input {and sticking a tongue out! :-) }
  U I           ; Use the TCP device
  R K           ; Read from STDIN (anything)
  F K=1:1:4{    ; Iterate 1->4 in variable K
    S J=J+      ; Accumulate the following segments of the IP in var. J
    $P(##class(%SYSTEM.TCPDevice).PeerAddr(),".",K) ; Grab each piece of IPv4.
            }   ; close the loop.
  W J,!         ; Write the total w/newline out the TCP port 
  C I           ; close the TCP port to send.
}               ; end final loop

यह Mumps का InterSystems Caché संस्करण है - अगर वहाँ एक ऐसा संस्करण है जो TCP पते से कम प्राप्त कर सकता है ##class(%SYSTEM.TCPDevice).PeerAddr() (जैसा कि यह पूरे कार्यक्रम का लगभग 1/3 है) तो यह पहले से ही पोस्ट की गई कुछ अन्य भाषाओं के मुकाबले बेहतर मौका हो सकता है। ... ;-)

संपादित करें: @TimmyD के लिए धन्यवाद - मैंने हार्डकोड किए जाने के बजाय STDIN या तर्कों से पोर्ट पढ़ने को याद किया। संपादित; इसने कार्यक्रम में 1 बाइट जोड़ी।


@ टिम्मीड - आह, आप सही हैं। याद किया कि आवश्यकताओं के माध्यम से पढ़ने पर। Posthaste संपादित करेंगे।
21

3

सी, 535 बाइट्स

खैर, किसी को यह करना था।

मैंने एक सिंगल लाइन ब्रेक जोड़ा इसलिए पोस्ट किए गए कोड में वास्तव में 536 अक्षर हैं।

#include <stdio.h>
#include <netdb.h>
#include <netinet/in.h>
#include <string.h>
int main(int c,char**v){int f,l;char b[99];struct sockaddr_in d,e;f=socket(AF_INET,SOCK_STREAM,0);bzero(&d,sizeof(d));d.sin_family=AF_INET;d.sin_addr.s_addr=INADDR_ANY;d.sin_port=htons(atoi(v[1]));bind(f,&d, sizeof(d));listen(f,5);l=sizeof(e);
f=accept(f,&e,&l);bzero(b,99);int p,q,r,s;char g[INET_ADDRSTRLEN];inet_ntop(AF_INET,&(e.sin_addr),g,INET_ADDRSTRLEN);sscanf(g,"%d.%d.%d.%d",&p,&q,&r,&s);sprintf(b,"%d\n",p+q+r+s);write(f,b,strlen(b));return 0;}

संकलन gcc [file_name] -o server

साथ दौड़ो ./server [port]

साथ जुडा हुआ telnet localhost [port]


3
अच्छा जवाब! जैसा कि पहले उल्लेख किया गया है , आप कुछ स्थिरांक जैसे AF_INET और SOCK_STAM के लिए वास्तविक मानों का उपयोग करके कुछ बाइट्स बचा सकते हैं।
हनीस करपिला

2

जावा, 210 बाइट्स

golfed:

p->{java.net.ServerSocket x=new java.net.ServerSocket(p);for(;;){try(java.net.Socket s=x.accept()){byte[]b=s.getInetAddress().getAddress();s.getOutputStream().write((0+b[0]+b[1]+b[2]+b[3]+"\n").getBytes());}}};

विस्तारित:

@FunctionalInterface interface Consumer { // Define an interface that allows a function that throws an exception.
  void accept(int port) throws Exception;
}

Consumer consumer = (port) -> {
  java.net.ServerSocket serverSocket = new java.net.ServerSocket(port);
    for (;;) {
      try (java.net.Socket socket = serverSocket.accept()) {
        byte[] bytes = socket.getInetAddress().getAddress();
        socket.getOutputStream().write((0 + b[0] + b[1] + b[2] + b[3] + "\n").getBytes());
      }
    }
}

यह उन सभी युक्तियों का एक संग्रह है जो मैंने अन्य जावा उत्तरों में दिए हैं, साथ ही एक पूर्ण कार्यक्रम के बजाय एक फ़ंक्शन के रूप में लेखन, जो कि कार्यक्रम की तुलना में लगभग 70 बाइट्स प्राप्त करता है।


2

हास्केल, 326 बाइट्स

import Data.Bits
import Network.Socket
import System.IO
f n=withSocketsDo$do
 s<-socket AF_INET Stream defaultProtocol
 bind s$SockAddrInet n iNADDR_ANY
 listen s 1
 g s
g s=do
 (z,SockAddrInet _ a)<-accept s
 h<-socketToHandle z WriteMode
 hPutStrLn h$show$b a
 hClose h
 g s
b 0=0
b x=x.&.0xFF+b(x`shiftR`8)

अफसोस की बात है कि मुझे Network.Socketएक स्ट्रिंग के बजाय पूर्णांक के रूप में दूरस्थ आईपी पते तक पहुंचने के लिए उपयोग करना था । यह वर्ण के दर्जनों बचाया है | अगर मैं कर सकता है s <- listenOn (PortNumber n)बल्कि स्पष्ट रूप से कॉल करने के लिए की तुलना में, socket, bindऔर listenव्यक्तिगत रूप से। लेकिन, दुख की बात है, Network.acceptमुझे एक होस्ट स्ट्रिंग देता है , न कि एक आईपी एड्रेस पूर्णांक , इसलिए मुझे Network.Socket.acceptऔर दोस्तों का सहारा लेना पड़ा ।

फ़ंक्शन fएक पोर्ट संख्या को तर्क के रूप में लेता है, और sउस पोर्ट पर एक सर्वर सॉकेट ( ) बनाता है । यह तब gसर्वर सॉकेट के साथ फ़ंक्शन को कॉल करता है । gहमेशा के लिए छोरों, कनेक्शन स्वीकार कर रहा है। फ़ंक्शन bवास्तविक IPv4 पता लेता है और इसके अंकों के योग की गणना करता है।

मुझे यकीन है कि कोई न कोई मुझसे बेहतर कर सकता है। मैं बस यह दिखाना चाहता था कि हास्केल में कितना आसान सॉकेट सामान है ... लेकिन तब बुरी तरह से विफल हो गया, क्योंकि मुझे आईपी पते तक पहुंच की आवश्यकता है, जो आमतौर पर प्राप्त करना आसान नहीं है।


"नेटवर्क-सरल" पैकेज एक बहुत अच्छा इंटरफ़ेस प्रदान करता है जो आपके द्वारा दिए गए फ़ंक्शन को SockAddr पास करता है, जो चीजों को आसान बनाता है। मेरा समाधान देखें जो मैं पोस्ट करने वाला हूं ...
जूल्स

कुछ सरलीकरण स्पष्ट हैं: (1) मेरा मानना withSocketsDoहै कि केवल विंडोज पर आवश्यक है, इसलिए यदि लिनक्स पर चल रहा है तो इसे अनदेखा किया जा सकता है; (2) 0xFF 255 से अधिक का वर्ण है; (3) सॉकेट को एक हैंडल में बदलना और नियमित IO का उपयोग करना उपयोग करने की तुलना में बहुत लंबा है Network.Socket.send। हां, sendवंचित है, लेकिन इसका कारण इस परिदृश्य के लिए प्रासंगिक नहीं है (यह केवल गैर-एएससीआईआई पाठ या द्विआधारी डेटा से संबंधित है), इसलिए इसका उपयोग करना उचित लगता है।
जूल्स

Network.accept gives me a host string, not an IP address integerक्या आप विभाजन स्ट्रिंग पर आईपी स्ट्रिंग ".", mapहास्केल के स्ट्रिंग-टू-नंबर फ़ंक्शन पर विभाजित नहीं कर सकते हैं और परिणाम योग कर सकते हैं?
बिल्ली

2

लुआ, 169 162 160 153 151 148 138 129 बाइट्स

गोल्फ संस्करण

m=require"socket".bind(0,...)::l::c=m:accept()f=0 for n in c:getpeername():gmatch"%d+"do f=f+n end c:send(f.."\n")c:close()goto l

इसे स्थापित करने के लिए ल्युसकेट की आवश्यकता होती है और एक दुभाषिया जो लेबल का समर्थन करता है। मैंने इसे लुजित के साथ परीक्षण किया है और मैं यह भी पुष्टि कर सकता हूं कि कोड लुआ 5.1 के साथ काम नहीं करता है।

अनप्लग्ड संस्करण

m=require"socket".bind(0,...)
::l::
c=m:accept()

f=0
for n in c:getpeername():gmatch"%d+" do
    f=f+n
end
c:send(f.."\n")

c:close()
goto l

1 संपादित करें:

बदला हुआ i=({c:getpeername()})[1]सिर्फi=c:getpeername()

2 संपादित करें:

आवश्यकता कथन से हटाए गए ब्रेसेस।

संपादित करें 3:

वरग के आस-पास के ब्रेसिज़ को हटा दिया, बाइट की गिनती को थोड़ा कम कर दिया।

4 संपादित करें:

"बाइट डी +" के आसपास कोष्ठक को हटा दिया, 2 बाइट्स से छोटा।

5 संपादित करें:

अनावश्यक चर को हटा दिया i।

संपादित करें 6:

आईपी ​​को "127.0.0.1" से 0. में बदल दिया (# लुआ पर xyzzy के लिए धन्यवाद)

7 संपादित करें:

फंक्शन कॉल को टोनर पर हटा दिया गया क्योंकि स्ट्रिंग्स स्वचालित रूप से संख्याओं में डाली जाती हैं (सुझाव के लिए ट्रेबुचेट के लिए धन्यवाद, मुझे यह नहीं पता था)


1
केवल लुआ 5.2 और अप सपोर्ट लेबल्स, अगर आप उत्सुक हैं
Trebuchette

1
इसके अलावा, लुआ स्वचालित रूप से +ऑपरेटर के साथ संख्याओं को तार देता है , ताकि आप बाहर निकाल सकें tonumber
त्रेब्यूचेते

2

हास्केल, 185 (+ 19 = 204)? बाइट्स

import Network.Simple.TCP(serve)
import Network.Socket
import Data.List.Split
main=getLine>>=flip(serve"*4")(\(a,b)->()<$(send a$(++"\n")$show$sum.map read.take 4.sepByOneOf":."$show b)

स्टड पर एक पंक्ति के रूप में पोर्ट नंबर लेता है; network-simpleकैबल से आवश्यकता है।

हस्केल के जवाब में हमेशा की तरह खुद को शुद्ध कार्यों के लिए विवश नहीं करना चाहिए, importsबहुत अधिक बाइट्स लेना चाहिए। अनुगामी न्यूलाइन भी 9 बाइट के लायक है ...

@ जूल्स के उत्तर के समान, लेकिन मैं बाइट संचालन के बजाय स्ट्रिंग हेरफेर का उपयोग करता हूं। मैं चुराया इस्तेमाल किया -XOverloadedStringsविस्तार के रूप में अच्छी तरह से है, जो शायद 19 बाइट्स के लायक अतिरिक्त है।


2

सी, 243 188 बाइट्स (या शायद 217 162 बाइट्स)

V2: स्पष्टीकरण के लिए नीचे देखें।

188 बाइट्स:

s;main(g,v)char**v;{short S[8]={2,htons(atoi(v[1]))};char C[g=16];bind(s=socket(2,1,0),&S,g);for(listen(s,8);g=fdopen(accept(s,&C,&g),"w");fclose(g))fprintf(g,"%d\n",C[4]+C[5]+C[6]+C[7]);}

थोड़ा बरमस्कैप 162 बाइट्स:

s;main(g){short S[8]={2,g};char C[g=16];bind(s=socket(2,1,0),&S,g);for(listen(s,8);g=fdopen(accept(s,&C,&g),"w");fclose(g))fprintf(g,"%d\n",C[4]+C[5]+C[6]+C[7]);}

संभवत: कल सुबह और अधिक गोल्फिंग संभव है। मैं इस पोस्ट को उन अपडेट के बाद साफ कर दूँगा।


V1:

यह एक वास्तव में गोल्फ के लिए काफी मजेदार था।

#include<netdb.h>
s,c,q;main(g,v)char**v;{struct sockaddr_in S={2,htons(atoi(v[1]))},C;bind(s=socket(2,1,0),&S,g=16);for(listen(s,8);c=accept(s,&C,&g);q=fclose(g)){for(g=4;g;q+=C.sin_addr.s_addr>>8*--g&255);fprintf(g=fdopen(c,"w"),"%d\n",q);}}

यह IPv4 के लिए काम करता है। ज्यादातर यह एक सीधा कार्यान्वयन है। तीन मुख्य घटक हैं

सॉकेट बनाना:

संरचना sockaddr_in S = {2, htons (atoi (v [1]))}, C, bind (s = सॉकेट (2,1,0), & S, g = 16);

हम निरंतर AF_INET आदि के विभिन्न स्पष्ट रूपों का उपयोग करते हैं, और इस तथ्य का उपयोग करते हैं कि जब कोई संरचना C में इस तरह से आरम्भ की जाती है, तो गैर-निर्दिष्ट तत्व शून्य पर सेट होते हैं।

ग्राहकों के लिए सुनो, उन्हें स्वीकार करें और उनके कनेक्शन बंद करें:

के लिए (सुनने (रों, 8), ग = स्वीकार (रों, और सी, और छ); q = fclose (छ))

अंत में प्रत्येक ग्राहक को डेटा भेजने के लिए:

के लिए (छ = 4; जी; क्ष + = C.sin_addr.s_addr >> 8 * - जी और 255); fprintf (छ = fdopen (ग, "डब्ल्यू"), "% d \ n", क्यू);

आईपी ​​को C.sin_addr.s_addr32 बिट पूर्णांक के रूप में संग्रहीत किया जाता है, जहां प्रत्येक ऑक्टेट को चार बाइट्स में से एक द्वारा दर्शाया जाता है। हम इन बाइट्स को लूप के लिए जोड़ते हैं और फिर उन्हें फप्रिंट का उपयोग करके स्ट्रीम पर प्रिंट करते हैं।

मेरे पास 217 बाइट समाधान है, लेकिन मुझे पूरी तरह से यकीन नहीं है कि यह मानक खामियों का उल्लंघन नहीं करता है क्योंकि इसके लिए आवश्यक है कि पोर्ट नेटवर्क बाइट क्रम में कमांड लाइन तर्क के रूप में अनुपयोगी हो। यानी पोर्ट 12345 पर सर्वर को चलाने के लिए किसी को कॉल करना होगा

$ ./tcp 1 1 1 1 ... 1 1 1

जहां s की कुल संख्या 114640 है। कम से कम कहने के लिए यह थोड़ा ... बोझिल है। लेकिन यहाँ यह वैसे भी है:

#include<netdb.h>
s,c,q;main(g){struct sockaddr_in S={2,g},C;bind(s=socket(2,1,0),&S,g=16);for(listen(s,8);c=accept(s,&C,&g);q=fclose(g)){for(g=4;g;q+=C.sin_addr.s_addr>>8*--g&255);fprintf(g=fdopen(c,"w"),"%d\n",q);}}

2

रैकेट, 265 बाइट्स

#lang racket(define l(tcp-listen(string->number(read-line))))(let e()(define-values(i o)(tcp-accept l))(thread(λ()(define-values(a b)(tcp-addresses o))(write(~a(foldl + 0(map string->number(string-split a".")))o))(newline o)(close-output-port o)))(e)))

Ungolfed:

#lang racket
(define listener (tcp-listen (string->number (read-line))))
(define (mk-server)
  (let echo-server ()
    (define-values (in out) (tcp-accept listener))
    (thread
     (λ()
       (define-values (a b) (tcp-addresses out))
       (write (number->string (foldl + 0(map string->number(string-split a "."))) out))
       (write "\n" out)
       (close-output-port out)))
    (echo-server)))

2

फैक्टर, 155 146 131 206 190 बाइट्स

खैर, मैंने अभी निम्न-स्तरीय सॉकेट प्रोग्रामिंग के बारे में बहुत कुछ सीखा है। मुझे नहीं लगता कि मैं कभी भी ऐसा करना चाहता हूं, क्योंकि मेरा थ्रू सिर दर्द करता है।

[ utf8 <threaded-server> readln 10 base> >>insecure [ remote-address get host>> "." split [ 10 base> ] map sum 10 >base print flush ] >>handler [ start-server ] in-thread start-server drop ]

ओह, हाँ, लड़ी पिरोया और वापस नहीं, सही है।


के 10 base>बजाय आप का उपयोग कर सकते हैं string>number?
फेड एस।

@fedes। वाह, मैं कभी नहीं जानता था कि अस्तित्व में है। मुझे लगता है कि मुझे मेरे बहुत सारे फैक्टर जवाबों को छोटा करने की अनुमति होगी!
बिल्ली

और 10 >baseनंबर> स्ट्रिंग के लिए भी।
फेड एस।

1
@fedes। वे यहाँ एक जवाब के लायक हैं : D
बिल्ली
हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.