spellchecker.cfm
上传用户:dbstep
上传日期:2022-08-06
资源大小:2803k
文件大小:5k
源码类别:

WEB源码(ASP,PHP,...)

开发平台:

ASP/ASPX

  1. <cfsetting enablecfoutputonly="true">
  2. <!---
  3. This code uses a CF User Defined Function and should work in CF version 5.0
  4. and up without alteration.
  5. Also if you are hosting your site at an ISP, you will have to check with them
  6. to see if the use of <CFEXECUTE> is allowed. In most cases ISP will not allow
  7. the use of that tag for security reasons. Clients would be able to access each
  8. others files in certain cases.
  9. --->
  10. <!--- The following variables values must reflect your installation. --->
  11. <cfset aspell_dir   = "C:Program FilesAspellbin">
  12. <cfset lang         = "en_US">
  13. <cfset aspell_opts  = "-a --lang=#lang# --encoding=utf-8 -H --rem-sgml-check=alt">
  14. <cfset tempfile_in  = GetTempFile(GetTempDirectory(), "spell_")>
  15. <cfset tempfile_out = GetTempFile(GetTempDirectory(), "spell_")>
  16. <cfset spellercss   = "../spellerStyle.css">
  17. <cfset word_win_src = "../wordWindow.js">
  18. <cfset form.checktext = form["textinputs[]"]>
  19. <!--- make no difference between URL and FORM scopes --->
  20. <cfparam name="url.checktext"  default="">
  21. <cfparam name="form.checktext" default="#url.checktext#">
  22. <!--- Takes care of those pesky smart quotes from MS apps, replaces them with regular quotes --->
  23. <cfset submitted_text = ReplaceList(form.checktext,"%u201C,%u201D","%22,%22")>
  24. <!--- submitted_text now is ready for processing --->
  25. <!--- use carat on each line to escape possible aspell commands --->
  26. <cfset text = "">
  27. <cfset CRLF = Chr(13) & Chr(10)>
  28. <cfloop list="#submitted_text#" index="field" delimiters=",">
  29. <cfset text = text & "%"  & CRLF
  30.                       & "^A" & CRLF
  31.                       & "!"  & CRLF>
  32. <!--- Strip all tags for the text. (by FredCK - #339 / #681) --->
  33. <cfset field = REReplace(URLDecode(field), "<[^>]+>", " ", "all")>
  34. <cfloop list="#field#" index="line" delimiters="#CRLF#">
  35. <cfset text = ListAppend(text, "^" & Trim(JSStringFormat(line)), CRLF)>
  36. </cfloop>
  37. </cfloop>
  38. <!--- create temp file from the submitted text, this will be passed to aspell to be check for misspelled words --->
  39. <cffile action="write" file="#tempfile_in#" output="#text#" charset="utf-8">
  40. <!--- execute aspell in an UTF-8 console and redirect output to a file. UTF-8 encoding is lost if done differently --->
  41. <cfexecute name="cmd.exe" arguments='/c type "#tempfile_in#" | "#aspell_dir#aspell.exe" #aspell_opts# > "#tempfile_out#"' timeout="100"/>
  42. <!--- read output file for further processing --->
  43. <cffile action="read" file="#tempfile_out#" variable="food" charset="utf-8">
  44. <!--- remove temp files --->
  45. <cffile action="delete" file="#tempfile_in#">
  46. <cffile action="delete" file="#tempfile_out#">
  47. <cfset texts = StructNew()>
  48. <cfset texts.textinputs = "">
  49. <cfset texts.words      = "">
  50. <cfset texts.abort      = "">
  51. <!--- Generate Text Inputs --->
  52. <cfset i = 0>
  53. <cfloop list="#submitted_text#" index="textinput">
  54.   <cfset texts.textinputs = ListAppend(texts.textinputs, 'textinputs[#i#] = decodeURIComponent("#textinput#");', CRLF)>
  55.   <cfset i = i + 1>
  56. </cfloop>
  57. <!--- Generate Words Lists --->
  58. <cfset word_cnt  = 0>
  59. <cfset input_cnt = -1>
  60. <cfloop list="#food#" index="aspell_line" delimiters="#CRLF#">
  61.     <cfset leftChar = Left(aspell_line, 1)>
  62. <cfif leftChar eq "*">
  63. <cfset input_cnt   = input_cnt + 1>
  64. <cfset word_cnt    = 0>
  65. <cfset texts.words = ListAppend(texts.words, "words[#input_cnt#] = [];", CRLF)>
  66. <cfset texts.words = ListAppend(texts.words, "suggs[#input_cnt#] = [];", CRLF)>
  67.     <cfelse>
  68.         <cfif leftChar eq "&" or leftChar eq "##">
  69. <!--- word that misspelled --->
  70. <cfset bad_word    = Trim(ListGetAt(aspell_line, 2, " "))>
  71. <cfset bad_word    = Replace(bad_word, "'", "'", "ALL")>
  72. <!--- sugestions --->
  73. <cfset sug_list    = Trim(ListRest(aspell_line, ":"))>
  74. <cfset sug_list    = ListQualify(Replace(sug_list, "'", "'", "ALL"), "'")>
  75. <!--- javascript --->
  76. <cfset texts.words = ListAppend(texts.words, "words[#input_cnt#][#word_cnt#] = '#bad_word#';", CRLF)>
  77. <cfset texts.words = ListAppend(texts.words, "suggs[#input_cnt#][#word_cnt#] = [#sug_list#];", CRLF)>
  78. <cfset word_cnt    = word_cnt + 1>
  79. </cfif>
  80.      </cfif>
  81. </cfloop>
  82. <cfif texts.words eq "">
  83.   <cfset texts.abort = "alert('Spell check complete.nnNo misspellings found.'); top.window.close();">
  84. </cfif>
  85. <cfcontent type="text/html; charset=utf-8">
  86. <cfoutput><html>
  87. <head>
  88. <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
  89. <link rel="stylesheet" type="text/css" href="#spellercss#" />
  90. <script language="javascript" src="#word_win_src#"></script>
  91. <script language="javascript">
  92. var suggs      = new Array();
  93. var words      = new Array();
  94. var textinputs = new Array();
  95. var error;
  96. #texts.textinputs##CRLF#
  97. #texts.words#
  98. #texts.abort#
  99. var wordWindowObj = new wordWindow();
  100. wordWindowObj.originalSpellings = words;
  101. wordWindowObj.suggestions = suggs;
  102. wordWindowObj.textInputs = textinputs;
  103. function init_spell() {
  104. // check if any error occured during server-side processing
  105. if( error ) {
  106. alert( error );
  107. } else {
  108. // call the init_spell() function in the parent frameset
  109. if (parent.frames.length) {
  110. parent.init_spell( wordWindowObj );
  111. } else {
  112. alert('This page was loaded outside of a frameset. It might not display properly');
  113. }
  114. }
  115. }
  116. </script>
  117. </head>
  118. <body onLoad="init_spell();">
  119. <script type="text/javascript">
  120. wordWindowObj.writeBody();
  121. </script>
  122. </body>
  123. </html></cfoutput>
  124. <cfsetting enablecfoutputonly="false">